SQL语句-INSERT语句
Insert语句
Insert语句三种写法:
mysql> desc students;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
|sid |int(11) |YES | |NULL | |
|sname |varchar(20) |YES | |NULL | |
+-------+-------------+------+-----+---------+-------+
Insert into students values(1,’aaa’);
Insert into students set sid=2,sname=‘bbb’;
Insert into students select * from students_bak;
mysql> select * from students;
+------+-------+
|sid |sname|
+------+-------+
| 1 | aaa |
| 2 | bbb |
| 3 | ccc |
+------+-------+
- 其中
insert...values和insert...set两种语句都是将指定的数据插入到现成的表中,而insert...select语句是将另外表中数据查出来并插入 到现成的表中 Partition子句代表可以将数据插入到指定的表分区中Tbl_name代表将数据插入到的目标表Col_name代表要插入指定数据的目标表列,如果是多列则用逗号 隔开,如果目标表中的某些列没有在Insert语句中指定,则这些列 会插入默认值,当然可以使用default显视指定插入默认值Values中除了可以指定确定的数值之外,还可以使用表达式expr
INSERT INTO tbl_name (col1,col2) VALUES(15,col1*2); -- 正确
INSERT INTO tbl_name (col1,col2) VALUES(col2*2,15); -- 错误
mysql> insert into students(sid,sname) values(4,'ddd');
mysql> insert into students(sid) values(5);
mysql> insert into students(sname) values('eee');
mysql> insert into students value(2*3,'fff');
mysql> select * from students;
+------+-------+
|sid |sname|
+------+-------+
| 1 |aaa |
| 2 |bbb |
| 3 | ccc |
| 4 |ddd |
| 5 | NULL |
|NULL |eee |
| 6 |fff |
+------+-------+
- Insert...values语句不光可以插入一条数据,也可以插入多条数据
INSERT INTO tbl_name(a,b,c) VALUES(1,2,3),(4,5,6),(7,8,9);
Insert into students values(7,’abc’),(8,’bcd’);
- Insert...values和insert...select语句的执行结果如下
- Records: 100 Duplicates: 0 Warnings: 0
- Records代表此语句操作了多少行数据,但不一定是多少行被插入的数据,因为如果存 在相同的行数据且违反了某个唯一性,则duplicates会显示非0数值,warning代表语句执 行过程中的一些警告信息
- low_priority关键词代表如果有其他链接正在读取目标表数据,则此insert语句需要等待读取完成
- low_priority和high_priority关键词仅在MyISAM, MEMORY, and MERGE三种存储引擎下才生效
- Ignore关键词代表insert语句如果违反主键和唯一键的约束条件,则不报错而只产生警告信息,违反的行被丢弃,而不是整个语句回退;在数据类型转换
有问题时如果有ignore则只产生警告信息,而不是语句回退
CREATE TABLE `students` (
`sid` int(11) DEFAULT NULL,
`sname` varchar(20) DEFAULT NULL,
`gender` int(11) DEFAULT NULL,
UNIQUE KEY `idx_st_sid` (`sid`),
KEY `idx_st_union` (`sname`,`sex`)
) ENGINE=InnoDB DEFAULT CHARSET=latin
mysql> select * from students;
+------+-------+--------+
|sid|sname|gender|
+------+-------+--------+
|1|abc| 1|
|2|abc| 1|
|3|abc| 1|
mysql> insert into students values(1,'bbb',0);
ERROR 1062 (23000): Duplicate entry '1' for key 'idx_st_sid'
mysql> insert ignore into students values(1,'bbb',0);
Query OK, 0 rows affected, 1 warning (0.01 sec)
mysql> show warnings;
+---------+------+------------------------------------------+
| Level | Code | Message |
+---------+------+------------------------------------------+
| Warning | 1062 | Duplicate entry '1' for key 'idx_st_sid' |
mysql> insert ignore into students values(1,'aa',0),(5,'bb',1);
Query OK, 1 row affected, 1 warning (0.03 sec)
Records: 2 Duplicates: 1 Warnings: 1
mysql> select * from students3;
+------+-------+--------+
|sid |sname|gender|
+------+-------+--------+
|1|a|0|
|2|b|0|
|4|c|1|
mysql> insert ignore into students select * from students3;
Query OK, 1 row affected, 2 warnings (0.01 sec)
Records: 3 Duplicates: 2 Warnings: 2
Insert...select语句详解
用于从另外的表中查出记录并插入到目标表中
INSERT INTO tbl_temp2 (fld_id)
SELECT tbl_temp1.fld_order_id
FROM tbl_temp1 WHERE tbl_temp1.fld_order_id > 100;
当目标表和select语句中的表相同时,则会先将select语句的结果 存放在临时表中,再插入到目标表中(注意执行顺序)
insert into students select * from students;
Insert delayed语句详解
在5.6.6版本之前,用来表示此插入语句当碰到其他链接正在使用 目标表时就等待,直到目标表没被用时再插入数据
在5.7版本时,delayed关键词就不再支持,但语句执行时不会报 错,只会产生一个警告信息,后续版本会去掉此关键词
insert delayed into students select * from students;
Query OK, 18 rows affected, 1 warning (0.00 sec)
Records: 18 Duplicates: 0 Warnings: 1
Insert on duplicate key update语句详解
当insert语句中使用on duplicate key update子句时,如果碰到当前 插入的数据违反主键或唯一键的唯一性约束,则Insert会转变成 update语句修改对应的已经存在表中的这条数据。比如如果a字段 有唯一性约束且已经含有1这条记录,则以下两条语句的执行结 果相同
INSERT INTO table (a,b,c) VALUES (1,2,3) ON DUPLICATE KEY UPDATE c=c+1;
UPDATE table SET c=c+1 WHERE a=1;
On duplicate key update子句后面可以跟多个修改,用逗号隔开
上述例子中如果b字段也有唯一性约束,则与此语句的执行结果 相同,但一般应该避免出现对应多条的情况
UPDATE table SET c=c+1 WHERE a=1 OR b=2 LIMIT 1;
Insert on duplicate key update语句详解
mysql> create table students2(sid int primary key,sname varchar(20),sex int);
Insert into students2 values(1,’aaa’,1); -- 插入成功
Insert into students2 values(1,’bbb’,0); -- 插入失败
mysql> insert into students2 values(1,'bbb',0);
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'
insert into students2 values(1,‘bbb’,0) on duplicate key update sname=‘bbb’;
+-----+-------+------+
| sid | sname | sex |
+-----+-------+------+
| 1 |bbb | 1 |
insert into students2 values(1,‘ccc’,0) on duplicate key update sname=‘ccc’,sex=0; -- 执行成功
将如下数据插入到dept表中
1,’computer science’ ; 2,’education’; 4,’accounting’
根据create table ... like语句创建teacher_backup表,并插入如下数 据:
1,’susan’,1; 2,’ruth’,4; 3,’vivian’,4
将teacher_backup表的数据通过insert...select语句插入到teacher表中
SQL语句-INSERT语句的更多相关文章
- 如何通过sql的insert语句插入大量字符串到oracle的clob字段?
当通过insert语句直接插入大量字符串(主要是html的内容),超过4000字符时候,就会报: ORA-01489: 字符串连接的结果过长 虽然字段是clob,足以存储,但是通过这种直接插入的时候, ...
- PL/SQL Developer如何导出数据成sql的insert语句
1.选择菜单 , [工具]-[导出表] 2.选择tab标签页的,[SQL插入] 注意where条件语句,注意要选择相应的表 3.选择输出
- Sql生成 Insert 语句
declare @TableName sysname select @TableName = 'T_OOSOrder' declare @result varchar(max) = 'INSERT I ...
- SQL基础语法—insert语句
1 insert语句 insert语句用于插入数据到表中,其基本语法有以下三种: Syntax: INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IG ...
- 第四章 数据更新 4-1 数据的插入(INSERT 语句的使用方法)
一.什么是INSERT 用来插入数据的SQL就是INSERT语句. 二.INSERT 语句的基本语法. 列清单 值清单 列清单和值清单的列数必须保持一致,如果不一致会出错. 原则上,执行一次I ...
- PL/SQL客户端中执行insert语句,插入中文乱码
问题描述:在PL/SQL客户端中执行insert语句,插入中文乱码 解决方案: 1.执行脚本 select userenv('language') from dual; 结果为AMERICAN_ ...
- Sql Server系列:Insert语句
1 INSERT语法 [ WITH <common_table_expression> [ ,...n ] ] INSERT { [ TOP ( expression ) [ PERCEN ...
- SQL Server 存储过程生成insert语句
你肯定有过这样的烦恼,同样的表,不同的数据库,加入你不能执行select insert 那么你肯定需要一条这样的存储过程,之需要传入表明,就会给你生成数据的插入语句. 当然数据表数量太大,你将最好用 ...
- 【SQL Sever】将SQL Sever中的一个数据表的数据导出为insert语句
例如:这SQL Sever中的一张数据表,想要将这张数据表中的数据 转化成一个一个的insert语句存储在txt的文档中,那么不论走到那里这个insert语句一执行,我们就能将这个数据表中的数据 ...
随机推荐
- Mark下js最大精确整数范围,业务中出现的疑难bug
今天在跟后端联调中,偶然发现几个数据的id居然一样,我就询问了下后端这是什么情况,然而后端告诉我说并没有相同的id,于是开始一起排查问题. 排查中发现,从后端拿来的数据在浏览器控制台NetWork ...
- 数据结构-堆 C与C++的实现
堆,是一种完全二叉树.而且在这颗树中,父节点必然大于(对于小顶堆为小于)子节点. 关于树的概念不了解可以看这里:http://www.cnblogs.com/HongYi-Liang/p/723144 ...
- 数据结构-栈(应用篇)之快速排序法-C和C++的实现
一.原理解析 快速排序法: 基本思路是,从第一个元素开始,把所有比它大的元素放在它后面,把所有比它小的元素放前面.然后划分它前面和后面的所有元素,分别再做快速排序,直到无法再划分为止. 在以下程序案例 ...
- Jeecg踩坑不完全指南
公司用了这个叫做jeecg的快速开发框架,我不知道有多少公司在用这个框架,园子里有的可以吱一声.个人觉得这框架唯一优势就是可以让不会ssh的人也能进行开发,只要你会J2SE,有web后台发开经验即可. ...
- 高通secury boot过程
整理内容网盘地址: 链接:https://share.weiyun.com/79c3920b4f2097d93b719b3149a7f3f9 (密码:4jm9cx) 相关内容网站: http://bl ...
- 关于python使用threadpool中的函数单个参数和多个参数用法举例
1.对单个元素的函数使用线程池: # encoding:utf-8 __author__='xijun.gong' import threadpool def func(name): print 'h ...
- JavaSE(八)之集合练习一
前面把Collection家族给学习完毕了,接下来我们通过几个练习来巩固前面的知识. 一.产生10个1-20之间的随机数要求随机数不能重复 import java.util.HashSet; impo ...
- BZOJ3529: [Sdoi2014]数表
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=3529 挺恶心的数论TAT... 设f[i]是i的约数和,这个可以nln(n)扫出来. ans= ...
- Open-air shopping malls(二分半径,两元交面积)
http://acm.hdu.edu.cn/showproblem.php?pid=3264 Open-air shopping malls Time Limit: 2000/1000 MS (Jav ...
- jQuery:图片自动变换
<script type="text/javascript"> var aa=0; //设置变换时间为2s var timeChange=2000; //定义数组 va ...