insert的语法
INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] [INTO] tbl_name [(col_name,...)] VALUES ({expr | DEFAULT},...),(...),... [ ON DUPLICATE KEY UPDATE col_name=expr, ... ] 或:INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] [INTO] tbl_name SET col_name={expr | DEFAULT}, ... [ ON DUPLICATE KEY UPDATE col_name=expr, ... ] 或:
INSERT [LOW_PRIORITY | HIGH_PRIORITY] [IGNORE] [INTO] tbl_name [(col_name,...)] SELECT ... [ ON DUPLICATE KEY UPDATE col_name=expr, ... ]
如果列清单和VALUES清单均为空清单,则INSERT会创建一个行,每个列都被设置为默认值:
INSERT INTO tbl_name () VALUES();
假设worker表只有name和email,插入一条数据
insert into worker values(“tom”,”tom@yahoo.com”);
批量插入多条数据
insert into worker values(‘tom','tom@yahoo.com'),(‘paul','paul@yahoo.com');
给出要赋值的那个列,然后再列出值的插入数据
insert into worker (name) values (‘tom'); insert into worker (name) values (‘tom'), (‘paul');
使用set插入数据
insert into worker set name='tom';
在 SET 子句中未命名的行都赋予一个缺省值,使用这种形式的 INSERT 语句不能插入多行。
一个expression可以引用在一个值表先前设置的任何列,例如:
INSERT INTO tbl_name (col1,col2) VALUES(15,col1*2); --但不能这样 INSERT INTO tbl_name (col1,col2) VALUES(col2*2,15);
使用INSERT…SELECT语句插入从其他表选择的行
insert into tbl_name1(col1,col2) select col3,col4 from tbl_name2; --如果每一列都有数据 insert into tbl_name1 select col3,col4 from tbl_name2;
查询不能包含一个ORDER BY子句,而且INSERT语句的目的表不能出现在SELECT查询部分的FROM子句.
ON DUPLICATE KEY UPDATE
如果您指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则执行旧行UPDATE。
--假设a,b为唯一索引,表table没有1,2这样的行是正常插入数据,冲突时,更新c列的值 INSERT INTO table (a,b,c) VALUES (1,2,3) ON DUPLICATE KEY UPDATE c=3; --或者是 INSERT INTO table (a,b,c) VALUES (1,2,3) ON DUPLICATE KEY UPDATE c=values(c); --引用其他列更新冲突的行 INSERT INTO table (a,b,c) VALUES (1,2,3),(4,5,6) ON DUPLICATE KEY UPDATE c=VALUES(a)+VALUES(b); 向一个已定义为NOT NULL的列中插入NULL。对于一个多行INSERT语句或INSERT INTO...SELECT语句,根据列数据的类型,列被设置为隐含的默认值。对于数字类型,默认值为0;对于字符串类型,默认值为空字符串('');对于日期和时间类型,默认值为“zero”值。
INSERT INTO...SELECT的ON DUPLICATE KEY UPDATE
insert into tbl_name1(a,b,c) select col1,col2,col3 from tbl_name2 ON DUPLICATE KEY UPDATE c=values(c);
INSERT DELAYED
如果您的客户端不能等待INSERT完成,则这个选项是非常有用的,当一个客户端使用INSERT DELAYED时,会立刻从服务器处得到一个确定。并且行被排入队列,当表没有被其它线程使用时,此行被插入。
使用INSERT DELAYED的另一个重要的好处是,来自许多客户端的插入被集中在一起,并被编写入一个块。这比执行许多独立的插入要快很多。
INSERT DELAYED INTO worker (name) values (‘tom'), (‘paul');
使用DELAYED时有一些限制:
1.INSERT DELAYED仅适用于MyISAM, MEMORY和ARCHIVE表。对于MyISAM表,如果在数据文件的中间没有空闲的块,则支持同时采用SELECT和INSERT语句。在这些情况下,基本不需要对MyISAM使用INSERT DELAYED。
2.INSERT DELAYED应该仅用于指定值清单的INSERT语句。服务器忽略用于INSERT DELAYED...SELECT语句的DELAYED和INSERT DELAYED...ON DUPLICATE UPDATE语句的DELAYED。
3.因为在行被插入前,语句立刻返回,所以您不能使用LAST_INSERT_ID()来获取AUTO_INCREMENT值。AUTO_INCREMENT值可能由语句生成。
4.对于SELECT语句,DELAYED行不可见,直到这些行确实被插入了为止。
5.DELAYED在从属复制服务器中被忽略了,因为DELAYED不会在从属服务器中产生与主服务器不一样的数据。
本文向大家介绍mysql select语句操作实例,包括了mysql select语句操作实例的使用技巧和注意事项,需要的朋友参考一下 Select的语法 SELECT用于恢复从一个或多个表中选择的行,并可以加入UNION语句和子查询。 每个select_expr都指示一个您想要恢复的列, table_references指示行从哪个表或哪些表中被恢复。 简单查询 ORDER BY查询 GROUP
本文向大家介绍Javascript操作表单实例讲解(下),包括了Javascript操作表单实例讲解(下)的使用技巧和注意事项,需要的朋友参考一下 在上篇文章给大家介绍了js操作表单实例讲解(下)的相关知识,本文接着给大家介绍Javascript操作表单实例讲解(下),具体详情如下所示: 一、文本域 ----------------------------- 操作文本域的值 value 属性 设置
本文向大家介绍JavaScript操作表单实例讲解(上),包括了JavaScript操作表单实例讲解(上)的使用技巧和注意事项,需要的朋友参考一下 一、获得表单引用 1>通过直接定位的方式来获取 2>通过集合的方式来获取引用 3>通过name直接获取“(只适用于表单) 二、获得表单元素的引用 1>直接获取 2>通过集合来获取 3>直接通过name的形式 表单对象.name 三、表单元素共同的属性和
本文向大家介绍Shell中的循环语句for、while、until实例讲解,包括了Shell中的循环语句for、while、until实例讲解的使用技巧和注意事项,需要的朋友参考一下 在编程语言中,循环语句是最基本的语法之一,在Shell(这里是Bash)中也不例外,再把以前自己写过的相关内容整理一下吧。 这里包括for/while/until循环,以及变量自增的语法实例。 Shell(以Bash
本文向大家介绍AngularJS基于MVC的复杂操作实例讲解,包括了AngularJS基于MVC的复杂操作实例讲解的使用技巧和注意事项,需要的朋友参考一下 实例如下: 以上这篇AngularJS基于MVC的复杂操作实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
本文向大家介绍python 3.6 +pyMysql 操作mysql数据库(实例讲解),包括了python 3.6 +pyMysql 操作mysql数据库(实例讲解)的使用技巧和注意事项,需要的朋友参考一下 版本信息:python:3.6 mysql:5.7 pyMysql:0.7.11 测试代码: 测试表: 执行结果: 以上这篇python 3.6 +pyMysql 操作mysql数据库(实