MYSQL数据库正确使用MySQL INSERT INTO语句

《MYSQL数据库正确使用MySQL INSERT INTO语句》要点:
本文介绍了MYSQL数据库正确使用MySQL INSERT INTO语句,希望对您有用。如果有疑问,可以联系我们。

MYSQL实例以下的文章主要介绍的是MySQL INSERT INTO语句的实际用法以及MySQL INSERT INTO语句中的相关语句的介绍,MySQL INSERT INTO语句在实际应用中是经常使用到的语句,所以对其相关的内容还是多多掌握为好.

MYSQL实例
INSERT [LOW_PRIORITY | DELAYED] [IGNORE] 
[INTO] tbl_name [(col_name,...)] 
VALUES (expression,...),(...),... 

MYSQL实例
MySQLINSERT INTO SELECT语句:

MYSQL实例
INSERT [LOW_PRIORITY | DELAYED] [IGNORE] 
[INTO] tbl_name [(col_name,...)] 
SELECT ... 

MYSQL实例
INSERT INTO语句:

MYSQL实例
INSERT [LOW_PRIORITY | DELAYED] [IGNORE] 
[INTO] tbl_name 
SET col_name=expression,col_name=expression,... 

MYSQL实例INSERT把新行插入到一个存在的表中,INSERTINTO... VALUES形式的语句基于明确指定的值插入行,MySQLINSERT INTO SELECT形式插入从其他表选择的行,有多个值表的INSERT INTO... VALUES的形式在MySQL 3.22.5或以后版本中支持,col_name=expression语法在MySQL 3.22.10或以后版本中支持.

MYSQL实例tbl_name是行应该被插入其中的表.列名表或SET子句指出语句为那一列指定值.

MYSQL实例如果你为INSERT ... VALUES或INSERT ... SELECT不指定列表,所有列的值必须在VALUES()表或由SELECT提供.如果你不知道表中列的顺序,使用DESCRIBE tbl_name来找出.

MYSQL实例任何没有明确地给出值的列被设置为它的缺省值.例如,如果你指定一个列表并没命名表中所有列,未命名的列被设置为它们的缺省值.缺省值赋值在7.7 CREATE TABLE句法中描述.

MYSQL实例一个expression可以引用在一个值表先前设置的任何列.例如,你能这样:

MYSQL实例
MySQL> INSERT INTO tbl_name (col1,col2) VALUES(15,col1*2); 

MYSQL实例但不能这样:

MYSQL实例
MySQL> INSERT INTO tbl_name (col1,col2) VALUES(col2*2,15); 

MYSQL实例如果你指定关键词LOW_PRIORITY,INSERT的执行被推迟到没有其他客户正在读取表.在这种情况下,客户必须等到插入语句完成后,如果表频繁使用,它可能花很长时间.这与INSERT DELAYED让客马上继续正好相反.

MYSQL实例如果你在一个有许多值行的INSERT中指定关键词IGNORE,表中任何复制一个现有PRIMARY或UNIQUE键的行被忽略并且不被插入.如果你不指定IGNORE,插入如果有任何复制现有关键值的行被放弃.你可用C API函数MySQL_info()检查多少行被插入到表中.

MYSQL实例如果MySQL用DONT_USE_DEFAULT_FIELDS选项配置,INSERT语句产生一个错误,除非你明确对需要一个非NULL值的所有列指定值.见4.7.3 典型configure选项.

MYSQL实例MySQLINSERT INTO ... SELECT语句满足下列条件:

MYSQL实例查询不能包含一个ORDER BY子句.

MYSQL实例INSERT语句的目的表不能出现在SELECT查询部分的FROM子句,因为这在ANSI SQL中被禁止让从你正在插入的表中SELECT.(问题是SELECT将可能发现在同一个运行期间内先前被插入的记录.当使用子选择子句时,情况能很容易混淆)

MYSQL实例AUTO_INCREMENT列象往常一样工作.

MYSQL实例如果你使用INSERT ... SELECT或INSERT ... VALUES语句有多个值列表,你可以使用C API函数MySQL_info()得到查询的信息.信息字符串的格式如下:

MYSQL实例Records: 100 Duplicates: 0 Warnings: 0

MYSQL实例Duplicates指出不能被插入的行的数量,因为他们与现有的唯一的索引值重复.Warnings指出在出现某些问题时尝试插入列值的次数.在下列任何条件下都可能发生错误:

MYSQL实例插入NULL到被声明了NOT NULL的列,列被设置为它的缺省值.

MYSQL实例将超出列范围的值设置给一个数字列,值被剪切为范围内适当的端点值.

MYSQL实例将数字列设成例如'10.34 a'的值,拖尾的垃圾被剥去并仍然是数字部分被插入.如果值根本不是一个数字,列被设置到0.

MYSQL实例把一个字符串插入到超过列的最大长度的一个CHAR、VARCHAR、TEXT或BLOB列中.值被截断为列的最大长度.

MYSQL实例把一个对列类型不合法的值插入到一个日期或时间列.列被设置为该列类型适当的“零”值.

MYSQL实例对于INSERT语句的DELAYED选项是MySQL专属的选项-如果你客户有不能等到INSERT完成,它是很有用的.当你为日记登录使用MySQL时,而且你也周期性地运行花很长时间完成的SELECT语句,这是一个常见的问题.DELAYED在面MySQL 3.22.15中被引入,它是MySQL对 ANSI SQL92 的一个扩展.

MYSQL实例当你使用INSERT DELAYED时,客户将马上准备好,并且当表不被任何其他的线程使用时,行将被插入.

MYSQL实例另一个使用INSERT DELAYED的主要好处是从很多客户插入被捆绑在一起并且写进一个块.这比做很多单独的插入要来的快.

MYSQL实例以上的相关内容就是对MySQL INSERT INTO语句的介绍,希望对大家的学习有所赞助.

《MYSQL数据库正确使用MySQL INSERT INTO语句》是否对您有启发,欢迎查看更多与《MYSQL数据库正确使用MySQL INSERT INTO语句》相关教程,学精学透。编程之家PHP学院为您提供精彩教程。

相关文章

在正式开始之前,我们先来看下 MySQL 服务器的配置和版本号信...
> [合辑地址:MySQL全面瓦解](https://www.cnblogs.c...
物理服务机的CPU、内存、存储设备、连接数等资源有限,某个时...
1 回顾 上一节我们详细讲解了如何对数据库进行分区操作,包括...
navicat查看某个表的所有字段的详细信息 navicat设计表只能一...
文章浏览阅读4.3k次。转载请把头部出处链接和尾部二维码一起...