详述数据库的高级操作之「主键冲突」问题的解决

栏目: 数据库 · 发布时间: 8年前

内容简介:详述数据库的高级操作之「主键冲突」问题的解决

数据的高级操作

数据的操作,无外乎 增删改查

新增数据的基本语法为:

  • insert into + 表名 + [(字段列表)] + values (值列表);

在数据插入的时候,假设主键对应的值已经存在,则插入失败!这就是主键冲突。

主键冲突

当主键存在冲突(duplicate key)的时候,可以选择性的进行处理,即更新或替换。

下面,以表 my_class 为例,进行测试:

详述数据库的高级操作之「主键冲突」问题的解决

其中, grade 为主键。

第一种情况:主键冲突,进行更新操作。

  • 基本语法: insert into + 表名 + [(字段列表:包含主键)] + values (值列表) on duplicate key update 字段 = 新值;

执行如下 SQL 语句,进行测试:

-- 测试主键冲突的 SQL 语句
insert into my_class values ('PM3527','B315');

详述数据库的高级操作之「主键冲突」问题的解决

如上图所示,当主键已经存在的时候,产生主键冲突。再执行如下 SQL 语言,解决主键冲突的问题:

-- 当主键冲突的时候,进行更新操作
insert into my_class values ('PM3527','B315')
-- 冲突处理
on duplicate key update
-- 更新主键值
room = 'B315';

详述数据库的高级操作之「主键冲突」问题的解决

第二种情况:主键冲突,选择替换操作。

  • 基本语法: replace insert into + 表名 + [(字段列表:包含主键)] + values (值列表);

执行如下 SQL 语句,进行测试:

-- 测试主键冲突的 SQL 语句
insert into my_class values ('PM3528','B215');

详述数据库的高级操作之「主键冲突」问题的解决

如上图所示,当主键已经存在的时候,产生主键冲突。再执行如下 SQL 语言,解决主键冲突的问题:

-- 当主键冲突的时候,进行替换操作
replace into my_class values ('PM3528','B215');

详述数据库的高级操作之「主键冲突」问题的解决

通过以上两种情况的演示,当再发生主键冲突的时候,咱们已经可以从容应对并解决啦!

温馨提示:符号 [] 括起来的内容,表示可选项;符号 + ,则表示连接的意思。

———— ☆☆☆ —— 返回 -> 史上最简单的 MySQL 教程 <- 目录 —— ☆☆☆ ————


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

人人都是产品经理

人人都是产品经理

苏杰 / 电子工业出版社 / 2012-6 / 45.00元

本书为《人人都是产品经理》的升级版,是写给“1到3岁的产品经理”的书,适合刚入门的产品经理、产品规划师、需求分析师,以及对做产品感兴趣的学生,用户体验、市场运营、技术部门的朋友们,特别是互联网、软件行业。作为一名“4岁的产品经理”,作者讲述了过去3年的经历与体会,与前辈们的书不同,本书就像你走到作者身边,说“嗨,哥们!晚上有空吃个饭吗,随便聊聊做产品的事吧”,然后作者说“好啊”。 书名叫“......一起来看看 《人人都是产品经理》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

URL 编码/解码
URL 编码/解码

URL 编码/解码

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具