正确使用MySQL INSERT INTO语句
以下的文章主要介绍的是mysql insert into语句的实际用法以及mysql insert into语句中的相关语句的介绍,mysql insert into语句在实际应用中是经常使用到的语句,所以对其相关的内容还是多多掌握为好。
insert [low_priority | delayed] [ignore] [into] tbl_name [(col_name,...)] values (expression,...),(...),...
mysqlinsert into select语句:
insert [low_priority | delayed] [ignore] [into] tbl_name [(col_name,...)] select ...
insert into语句:
insert [low_priority | delayed] [ignore] [into] tbl_name set col_name=expression, col_name=expression, ...
insert把新行插入到一个存在的表中,insertinto... values形式的语句基于明确指定的值插入行,mysqlinsert into select形式插入从其他表选择的行,有多个值表的insert into... values的形式在mysql 3.22.5或以后版本中支持,col_name=expression语法在mysql 3.22.10或以后版本中支持。
tbl_name是行应该被插入其中的表。列名表或set子句指出语句为那一列指定值。
如果你为insert ... values或insert ... select不指定列表,所有列的值必须在values()表或由select提供。如果你不知道表中列的顺序,使用describe tbl_name来找出。
任何没有明确地给出值的列被设置为它的缺省值。例如,如果你指定一个列表并没命名表中所有列,未命名的列被设置为它们的缺省值。缺省值赋值在7.7 create table句法中描述。
一个expression可以引用在一个值表先前设置的任何列。例如,你能这样:
mysql> insert into tbl_name (col1,col2) values(15,col1*2);
但不能这样:
mysql> insert into tbl_name (col1,col2) values(col2*2,15);
如果你指定关键词low_priority,insert的执行被推迟到没有其他客户正在读取表。在这种情况下,客户必须等到插入语句完成后,如果表频繁使用,它可能花很长时间。这与insert delayed让客马上继续正好相反。
如果你在一个有许多值行的insert中指定关键词ignore,表中任何复制一个现有primary或unique键的行被忽略并且不被插入。如果你不指定ignore,插入如果有任何复制现有关键值的行被放弃。你可用c api函数mysql_info()检查多少行被插入到表中。
如果mysql用dont_use_default_fields选项配置,insert语句产生一个错误,除非你明确对需要一个非null值的所有列指定值。见4.7.3 典型configure选项。
mysqlinsert into ... select语句满足下列条件:
查询不能包含一个order by子句。
insert语句的目的表不能出现在select查询部分的from子句,因为这在ansi sql中被禁止让从你正在插入的表中select。(问题是select将可能发现在同一个运行期间内先前被插入的记录。当使用子选择子句时,情况能很容易混淆)
auto_increment列象往常一样工作。
如果你使用insert ... select或insert ... values语句有多个值列表,你可以使用c api函数mysql_info()得到查询的信息。信息字符串的格式如下:
records: 100 duplicates: 0 warnings: 0
duplicates指出不能被插入的行的数量,因为他们与现有的唯一的索引值重复。warnings指出在出现某些问题时尝试插入列值的次数。在下列任何条件下都可能发生错误:
插入null到被声明了not null的列,列被设置为它的缺省值。
将超出列范围的值设置给一个数字列,值被剪切为范围内适当的端点值。
将数字列设成例如'10.34 a'的值,拖尾的垃圾被剥去并仍然是数字部分被插入。如果值根本不是一个数字,列被设置到0。
把一个字符串插入到超过列的最大长度的一个char、varchar、text或blob列中。值被截断为列的最大长度。
把一个对列类型不合法的值插入到一个日期或时间列。列被设置为该列类型适当的“零”值。
对于insert语句的delayed选项是mysql专属的选项-如果你客户有不能等到insert完成,它是很有用的。当你为日记登录使用mysql时,而且你也周期性地运行花很长时间完成的select语句,这是一个常见的问题。delayed在面mysql 3.22.15中被引入,它是mysql对 ansi sql92 的一个扩展。
当你使用insert delayed时,客户将马上准备好,并且当表不被任何其他的线程使用时,行将被插入。
另一个使用insert delayed的主要好处是从很多客户插入被捆绑在一起并且写进一个块。这比做很多单独的插入要来的快。
以上的相关内容就是对mysql insert into语句的介绍,希望对大家的学习有所帮助。