史上最简单的 MySQL 教程(二十)「数据的高级操作 之 主键冲突」
来源:互联网 发布:泪目什么意思网络词 编辑:程序博客网 时间:2024/05/22 08:50
数据的高级操作
数据的操作,无外乎增删改查。
新增数据的基本语法为:
insert into + 表名 + [(字段列表)] + values (值列表);
在数据插入的时候,假设主键对应的值已经存在,则插入失败!这就是主键冲突。
主键冲突
当主键存在冲突(duplicate key)的时候,可以选择性的进行处理,即更新或替换。
下面,以表my_class
为例,进行测试:
其中,grade
为主键。
第一种情况:主键冲突,进行更新操作。
- 基本语法:
insert into + 表名 + [(字段列表:包含主键)] + values (值列表) on duplicate key update 字段 = 新值;
执行如下 SQL 语句,进行测试:
- 1
- 2
- 1
- 2
如上图所示,当主键已经存在的时候,产生主键冲突。再执行如下 SQL 语言,解决主键冲突的问题:
- 1
- 2
- 3
- 4
- 5
- 6
- 1
- 2
- 3
- 4
- 5
- 6
第二种情况:主键冲突,选择替换操作。
- 基本语法:
replace insert into + 表名 + [(字段列表:包含主键)] + values (值列表);
执行如下 SQL 语句,进行测试:
- 1
- 2
- 1
- 2
如上图所示,当主键已经存在的时候,产生主键冲突。再执行如下 SQL 语言,解决主键冲突的问题:
- 1
- 2
- 1
- 2
通过以上两种情况的演示,当再发生主键冲突的时候,咱们已经可以从容应对并解决啦!
温馨提示:符号[]
括起来的内容,表示可选项;符号+
,则表示连接的意思。
阅读全文
0 0
- 史上最简单的 MySQL 教程(二十)「数据的高级操作 之 主键冲突」
- 史上最简单的 MySQL 教程(二十)「数据的高级操作 之 主键冲突」
- 史上最简单的 MySQL 教程(二十三)「数据的高级操作 之 查询(上)」
- 史上最简单的 MySQL 教程(二十四)「数据的高级操作 之 查询(中)」
- 史上最简单的 MySQL 教程(二十五)「数据的高级操作 之 查询(下)」
- 史上最简单的 MySQL 教程(二十三)「数据的高级操作 之 查询(上)」
- 史上最简单的 MySQL 教程(二十四)「数据的高级操作 之 查询(中)」
- 史上最简单的 MySQL 教程(二十一)「数据的高级操作 之 蠕虫复制」
- 史上最简单的 MySQL 教程(二十二)「数据的高级操作 之 更新 & 删除」
- 史上最简单的 MySQL 教程(二十一)「数据的高级操作 之 蠕虫复制」
- 史上最简单的 MySQL 教程(二十二)「数据的高级操作 之 更新 & 删除」
- 史上最简单的 MySQL 教程(六)「SQL 基本操作 之 数据操作」
- 史上最简单的 MySQL 教程(十四)「列属性 之 主键」
- 史上最简单的 MySQL 教程(十)「列类型 之 日期时间型」
- 史上最简单的 MySQL 教程(四)「SQL 基本操作 之 库操作」
- 史上最简单的 MySQL 教程(五)「SQL 基本操作 之 表操作」
- MYSQL关于INSERT操作主键冲突的几个解决方案
- 史上最简单的 MySQL 教程(二十六)「连接查询(上)」
- MySQL数据库概述和常用管理命令
- Elevator
- 蓝创大庆十周年,三重大礼享不停
- 2017 Multi-University Training Contest
- 数据库设计四范式
- 史上最简单的 MySQL 教程(二十)「数据的高级操作 之 主键冲突」
- UML中关系在代码中的体现
- Java的封装
- 【实战】电脑 开发板 虚拟机三者互ping通教程
- H2:构建单元测试的本地内存数据库
- leetcode hard模式专杀之135. Candy
- 史上最简单的 MySQL 教程(二十一)「数据的高级操作 之 蠕虫复制」
- Qt Pro 文件配置
- 史上最简单的 MySQL 教程(二十二)「数据的高级操作 之 更新 & 删除」