MySQL INSERT INTO语句的正确用法 (mysqlinnodb和myisam)

技术教程 2025-04-27 07:31:38 浏览
INSERT

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

MySQLINSERT INTO SELECT语句:

INSERT INTO语句:

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可以引用在一个值表先前设置的任何列。例如,你能这样:

但不能这样:

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

INTO语句的正确用法

如果你在一个有许多值行的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的主要好处是从很多客户插入被捆绑在一起并且写进一个块。这比做很多单独的插入要来的快。

【编辑推荐】


pl/sql和sql语句的区别

SQL*plus是与Oracle进行交互的客户端工具。在sql*plus中,可以运行sql*plus命令与sql*plus语句pl/sql是工具软件,很多sql语句不能在pl/sql执行,如:shutdown,set Serveroutput on都不能执行

数据库里面如何删除一个行数据?

删除语句的基本结构为DELETE FROM 表名称 WHERE 列名称 = 值如果筛选条件多余一列的时候可以使用 AND或OR将条件连接起来例如有一张Person表,如下图所示要删除lastName为Willson的则Delete from Person where lastName=Willson;执行该语句后,Willson这条记录将会被删除。拓展资料一些常用的SQL语句:

insert into的用法

用Insert Into,可以用Select 语句插入值,但是最好是把字段名列出,以免表发生变动时语句失败 INSERT INTO [Table] ([Field1],[Field2]......[Fieldn]) SELECT [Field1],[Field2]......[Fieldn] FROM [Table1]..... 使用SELECT查询的字段数必须与INSERT中指定的字段数完全相等,并且数据类型能兼容(支持隐性转换) 对于一些不能进行隐性转换的数据,需要在SELECT中进行显式转换 例如字段中的类型是Varchar,而SELECT中的是Money,此时就必须进行显式转换才能插入成功。

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐