Mysql学习Mysql INSERT INTO语句用法详解

2020-06-09

编程之家收集整理的这篇文章主要介绍了Mysql学习Mysql INSERT INTO语句用法详解,编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

《MysqL学习MysqL INSERT INTO语句用法详解》要点:

本文介绍了MysqL学习MysqL INSERT INTO语句用法详解,希望对您有用。如果有疑问,可以联系我们。@H_404_6@导读:MysqL数据库中,INSERT INTO语句的结构: INSERT [LOW_PRIORITY | DELAYED] [IGNORE][INTO] tbl_name [(col_name,...)]VALUES (ex...

MysqL数据库中,INSERT INTO语句的结构:

INSERT [LOW_PRIORITY | DELAYED] [IGNORE]

[INTO] tbl_name [(col_name,...)]

VALUES (expression,...),(...),...

INSERT 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形式的语句基于明确指定的值插入行,INSERT 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值的所有列指定值.

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

注意,当前排队的行只是存储在内存中,直到他们被插入到表中.这意味着,如果硬要杀死MysqLd(kill -9)或如果MysqLd出人意料地死掉,没被写进磁盘的任何排队的行被丢失!

下列详细描述当为INSERT或REPLACE使用DELAYED选项时,发生什么.在这个描述中,“线程”是收到一个INSERT DELAYED命令的线程并且“处理器”是处理所有对于一个特定表的INSERT DELAYED语句.

当一个线程对一个表执行一个DELAYED语句时,如果不存在这样的处理程序,一个处理器线程被创建以处理对于该表的所有DELAYED语句.

线程检查处理程序是否已经获得了一个DELAYED锁;如果没有,它告诉处理程序去获得.即使其他的线程有在表上的一个READ或WRITE锁,也能获得DELAYED锁.然而,处理程序将等待所有ALTER TABLE锁或FLUSH TABLES以保证表结构是最新的.

线程执行INSERT语句,但不是将行写入表,它把最后一行的副本放进被处理器线程管理的一个队列.任何语法错误都能被线程发觉并报告给客户程序.

顾客不能报告结果行的重复次数或AUTO_INCREMENT值;它不能从服务器获得它们,因为INSERT在插入操作完成前返回.如果使用C API,同样原因,MysqL_info()函数不返回任何有意义的东西.

当行被插入到表中时,更新日志有处理器线程更新.在多行插入的情况下,当第一行被插入时,更新日志被更新.

在每写入delayed_insert_limit行后,处理器检查是否任何SELECT语句仍然是未完成,如果这样,在继续之前允许执行这些语句.

当处理器在它的队列中没有更多行时,表被解锁.如果在delayed_insert_timeout秒内没有收到新的INSERT DELAYED命令,处理器终止.

如果已经有多于delayed_queue_size行在一个特定的处理器队列中未办理,线程等待直到队列有空间.这有助于保证MysqLd服务器对延迟的内存队列不使用所有内存.

处理器线程将在Command列的MysqL进程表中显示delayed_insert.如果执行一个FLUSH TABLES命令或以KILL thread_id杀死它,它将被杀死,然而,它在退出前首先将所有排队的行存进表中.在这期间,这次它将不从其他线程接受任何新的INSERT命令.如果在它之后执行一个INSERT DELAYED,将创建一个新的处理器线程.

注意,如果有一个INSERT DELAYED处理器已经运行,INSERT DELAYED命令有比正常INSERT更高的优先级!其他更新命令将必须等到INSERT DELAY排队变空、杀死处理器线程(用KILL thread_id)或执行FLUSH TABLES.

以下的状态变量提供了关于INSERT DELAYED命令的信息: Delayed_insert_threads 处理器线程数量

Delayed_writes 用INSERT DELAYED被写入的行的数量

Not_flushed_delayed_rows 等待被写入的行数字

能通过发出一个SHOW STATUS语句或通过执行一个MysqLadmin extended-status命令察看这些变量.

注意,如果表不在使用,INSERT DELAYED比一个正常的INSERT慢.

对服务器也有额外开销来处理对它使用INSERT DELAYED的每个表的一个单独线程.

也就是说,应该只在确实肯定需要它的时候才使用INSERT DELAYED!

以上就是MysqL INSERT INTO语句用法的全部内容,希望对大家有所赞助.

编程之家PHP培训学院每天发布《MysqL学习MysqL INSERT INTO语句用法详解》等实战技能,PHP、MysqL、LINUX、APP、JS,CSS全面培养人才。

相关文章

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

如您喜欢交流学习经验,点击链接加入交流1群:1065694478(已满)交流2群:163560250

mysql insert详解_Mysql学习Mysql INSERT INTO语句用法详解相关推荐

  1. mysql 存储引擎作用_MySQL常用存储引擎功能与用法详解

    MySQL存储引擎主要有两大类: 1. 事务安全表:InnoDB.BDB. 2. 非事务安全表:MyISAM.MEMORY.MERGE.EXAMPLE.NDB Cluster.ARCHIVE.CSV. ...

  2. mysql聚合函数统计_mysql学习-mysql聚合函数和分组统计

    一.聚合函数 聚合函数.称为统计函数 常用的聚合函数 count()总量数 max()最大值 min()最小值 sum()和 avg()平均值 例:查询部门30的总人数(查询总人数,根据empno编号 ...

  3. mysql like escape_mysql like语句用法详解 含通配符使用方法

    mysql like语句用法详解 含通配符使用方法2017-11-07 20:46 在对数据进行模糊查询的时候,我们基本上都会用到like语句. 我们先来了解一下like语句中的通配符:百分号(%). ...

  4. mysql 如何对表排序_学习MySQL:对表中的数据进行排序和过滤

    mysql 如何对表排序 In this article, we will learn how we can sort and filter data using the WHERE clause a ...

  5. mysql分页是物理分页_学习MySQL:什么是分页

    mysql分页是物理分页 In this article, I am going to explain that in MySQL, what is pagination and how we can ...

  6. python scatter参数详解_Python 中 scatter 函数参数及用法详解

    Python 中 scatter 函数参数及用法详解 Python 中 scatter 函数参数及用法详解 这里有新鲜出炉的 Python 教程, 程序狗速度看过来! Python 编程语言 Pyth ...

  7. c语言for表达式1的作用,C语言for语句用法详解

    C语言for语句用法详解 C语言是一门高级计算机编程语言,设计目标是提供一种能以简易的方式编译.处理低级存储器.产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言.下面小编给大家介绍C语言f ...

  8. java if 用法详解_Java if判断语句用法详解

    Java if判断语句用法详解 if关键字中文意思是如果,其细致的语法归纳来说总共有三种:if语句.if-else语句和if-else if-else语句,下面重点介绍if语句. if语句 语法 if ...

  9. 【C语言for语句用法详解】

    ** C语言for语句用法详解 说明 for语句用于重复执行一段语句块.通常会使用一个增量计数器递增和终止循环.for语句对于任何需要重复的操作是非常有用的. 结构 for(表达式1; 表达式2; 表 ...

  10. mysql select语句详解_mysql学习笔记之完整的select语句用法实例详解

    本文实例讲述了mysql学习笔记之完整的select语句用法.分享给大家供大家参考,具体如下: 本文内容: 完整语法 去重选项 字段别名 数据源 where group by having order ...

最新文章

  1. 求只有2,3,5组成的第n小个数字
  2. oracle数据库查询代码,ORACLE数据库查询表实例代码
  3. Windows 10——安装Snort_2_9_16
  4. 在使用DBCA时报错,第二个节点无法启动数据库实例
  5. MongoDB最简单的入门教程之三 使用Java代码往MongoDB里插入数据
  6. html禁用自动完成,html – 如何禁用所有主流浏览器的自动完成功能
  7. word制作电子签名
  8. css3弹性盒子、媒体查询、多列布局
  9. mysql配置所有ip连接_Mysql查看用户连接数配置及每个IP的请求情况
  10. oc - runtime运行机制
  11. 基于Layabox引擎的魔塔微信小游戏设计与实现
  12. ansys时间步长怎么设置_ANSYS瞬态动力学分析中的时间步长的选择
  13. 使用python对字符串进行md5加密
  14. SQL Server密码破解工具
  15. nginx配置静态资源,重新发布后,浏览器缓存导致异常原因和解决
  16. mongodb pymongo
  17. 开源 | 智能家居场景,基于 AriKiss 配网的微信小程序
  18. 互联网,自媒体和微创新
  19. 用Python写一个图片标注工具
  20. 组织行为学对项目管理的意义(1)

热门文章

  1. 计算机资源管理器经常停止运行,解决win10资源管理器经常停止工作的方法
  2. ASP连接Oracle数据库简易DEMO完全案例
  3. 20寸JAVA16速自行车_健康成长 快乐骑行 JAVA16/20寸儿童自行车介绍
  4. 如何写项目方案--从资料准备到书写技巧
  5. Linux系统root用户登录后显示 “-bash-4.2#” 解决方案
  6. win10 系统 chrome内核浏览器 微软雅黑字体难看的解决方法
  7. protobuf中repeated类型变量与C++ vector类型变量的相互赋值方法
  8. 隔壁孩子10篇博客node入门而且写了一个前后端分离项目,你怎么还在睡觉!!!(五)
  9. SQL AND OR 运算符的用法
  10. python里面and和or用法