史上最简单的 MySQL 教程(二十)「数据的高级操作 之 主键冲突」
2017-08-06 15:18
1361 查看
数据的高级操作
数据的操作,无外乎增删改查。新增数据的基本语法为:
insert into + 表名 + [(字段列表)] + values (值列表);
在数据插入的时候,假设主键对应的值已经存在,则插入失败!这就是主键冲突。
主键冲突
当主键存在冲突(duplicate key)的时候,可以选择性的进行处理,即更新或替换。下面,以表
my_class为例,进行测试:
其中,
grade为主键。
第一种情况:主键冲突,进行更新操作。
基本语法:
insert into + 表名 + [(字段列表:包含主键)] + values (值列表) on duplicate key update 字段 = 新值;
执行如下 SQL 语句,进行测试:
-- 测试主键冲突的 SQL 语句 insert into my_class values ('PM3527','B315');1
2
1
2
如上图所示,当主键已经存在的时候,产生主键冲突。再执行如下 SQL 语言,解决主键冲突的问题:
-- 当主键冲突的时候,进行更新操作 insert into my_class values ('PM3527','B315') -- 冲突处理 on duplicate key update -- 更新主键值 room = 'B315';1
2
3
4
5
6
1
2
3
4
5
6
第二种情况:主键冲突,选择替换操作。
基本语法:
replace insert into + 表名 + [(字段列表:包含主键)] + values (值列表);
执行如下 SQL 语句,进行测试:
-- 测试主键冲突的 SQL 语句 insert into my_class values ('PM3528','B215');1
2
1
2
如上图所示,当主键已经存在的时候,产生主键冲突。再执行如下 SQL 语言,解决主键冲突的问题:
-- 当主键冲突的时候,进行替换操作 replace into my_class values ('PM3528','B215');1
2
1
2
通过以上两种情况的演示,当再发生主键冲突的时候,咱们已经可以从容应对并解决啦!
温馨提示:符号
[]括起来的内容,表示可选项;符号
+,则表示连接的意思。
相关文章推荐
- 史上最简单的 MySQL 教程(二十)「数据的高级操作 之 主键冲突」
- 史上最简单的 MySQL 教程(二十三)「数据的高级操作 之 查询(上)」
- 史上最简单的 MySQL 教程(二十五)「数据的高级操作 之 查询(下)」
- 史上最简单的 MySQL 教程(二十四)「数据的高级操作 之 查询(中)」
- 史上最简单的 MySQL 教程(二十三)「数据的高级操作 之 查询(上)」
- 史上最简单的 MySQL 教程(二十一)「数据的高级操作 之 蠕虫复制」
- 史上最简单的 MySQL 教程(二十二)「数据的高级操作 之 更新 & 删除」
- 史上最简单的 MySQL 教程(二十二)「数据的高级操作 之 更新 & 删除」
- 史上最简单的 MySQL 教程(二十一)「数据的高级操作 之 蠕虫复制」
- 史上最简单的 MySQL 教程(二十四)「数据的高级操作 之 查询(中)」
- 史上最简单的 MySQL 教程(二十三)「数据的高级操作 之 查询」
- MySQL基础教程26-数据高级操作-更新
- 史上最简单的 MySQL 教程(六)「SQL 基本操作 之 数据操作」
- MySQL基础教程25-数据高级操作-新增
- Mysql入门(四)之数据高级操作
- MySQL 主键冲突,无法插入数据
- mySQL学习入门教程——5.常用的高级操作
- MySQL 主键冲突,无法插入数据
- MySQL插入数据提示主键冲突,msg:Duplicate entry...............
- 03、Mysql 索引及高级数据操作