正确使用MySQL INSERT INTO语句


Posted in MySQL onMay 26, 2021

以下的文章主要介绍的是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语句的介绍,希望对大家的学习有所帮助。

MySQL 相关文章推荐
MySQL表的增删改查基础教程
Apr 07 MySQL
MySQL sql_mode修改不生效的原因及解决
May 07 MySQL
MySQL sql_mode的使用详解
May 08 MySQL
Mysql效率优化定位较低sql的两种方式
May 26 MySQL
Mysql数据库中datetime、bigint、timestamp来表示时间选择,谁来存储时间效率最高
Aug 23 MySQL
MySQL分区表实现按月份归类
Nov 01 MySQL
Mysql数据库手动及定时备份步骤
Nov 07 MySQL
分享mysql的current_timestamp小坑及解决
Nov 27 MySQL
如何避免mysql启动时错误及sock文件作用分析
Jan 22 MySQL
MySQL实战记录之如何快速定位慢SQL
Mar 23 MySQL
解决Mysql报错 Table 'mysql.user' doesn't exist
May 06 MySQL
mysql字段为NULL索引是否会失效实例详解
May 30 MySQL
正确使用MySQL update语句
May 26 #MySQL
详解MySQL集群搭建
MySQL中VARCHAR与CHAR格式数据的区别
May 26 #MySQL
修改MySQL的默认密码的四种小方法
May 26 #MySQL
修改MySQL的数据库引擎为INNODB的方法
May 26 #MySQL
Mysql数据库命令大全
May 26 #MySQL
Mysql基础知识点汇总
May 26 #MySQL
You might like
PHP输出控制功能在简繁体转换中的应用
2006/10/09 PHP
聊天室php&mysql(二)
2006/10/09 PHP
一个简单的php实现的MySQL数据浏览器
2007/03/11 PHP
Zend framework处理一个http请求的流程分析
2010/02/08 PHP
PHP中使用GD库创建圆形饼图的例子
2014/11/19 PHP
php中JSON的使用与转换
2015/01/14 PHP
PHP如何实现订单的延时处理详解
2017/12/30 PHP
JavaScript版DateAdd和DateDiff函数代码
2012/03/01 Javascript
Javascript之this关键字深入解析
2013/11/12 Javascript
jquery内置验证(validate)使用方法示例(表单验证)
2013/12/04 Javascript
JavaScript类型系统之基本数据类型与包装类型
2016/01/06 Javascript
JS生成一维码(条形码)功能示例
2017/01/19 Javascript
JavaScript获取当前时间向前推三个月的方法示例
2017/02/04 Javascript
vue页面使用阿里oss上传功能的实例(一)
2017/08/09 Javascript
JS组件系列之Gojs组件 前端图形化插件之利器
2017/11/29 Javascript
vue cli 3.0 搭建项目的图文教程
2019/05/17 Javascript
vue通过数据过滤实现表格合并
2020/11/30 Javascript
layui2.0使用table+laypage实现真分页
2019/07/27 Javascript
vue中使用element组件时事件想要传递其他参数的问题
2019/09/18 Javascript
微信小程序scroll-view点击项自动居中效果的实现
2020/03/25 Javascript
[52:03]Secret vs VG 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
在Python中使用PIL模块对图片进行高斯模糊处理的教程
2015/05/05 Python
Python3中使用urllib的方法详解(header,代理,超时,认证,异常处理)
2016/09/21 Python
Python使用QRCode模块生成二维码实例详解
2017/06/14 Python
python2与python3中关于对NaN类型数据的判断和转换方法
2018/10/30 Python
Python上下文管理器用法及实例解析
2019/11/11 Python
CSS3字体效果的设置方法小结
2016/06/13 HTML / CSS
EJB timer的种类
2014/10/28 面试题
自我鉴定书范文
2013/10/02 职场文书
告诉你怎样写创业计划书
2014/01/27 职场文书
《三峡》教学反思
2014/03/01 职场文书
酒鬼酒广告词
2014/03/21 职场文书
培训讲师岗位职责
2014/04/13 职场文书
文员试用期转正自我鉴定
2014/09/14 职场文书
pytorch 实现多个Dataloader同时训练
2021/05/29 Python
Python Matplotlib绘制等高线图与渐变色扇形图
2022/04/14 Python