当前位置: 首页 > wzjs >正文

论述网站建设过程中应注意的问题丹江口市建设局网站

论述网站建设过程中应注意的问题,丹江口市建设局网站,好推建站,副业做网站软件我们日常使用 insert into 语句向表中插入数据时,一定遇到过主键或唯一索引冲突的情况,MySQL的反应是报错并停止执行后续的语句,而replace into语句可以实现强制插入。 文章目录 一、replace into 语句简介1.1 基本用法1.2 使用set语句 二、注…

我们日常使用 insert into 语句向表中插入数据时,一定遇到过主键或唯一索引冲突的情况,MySQL的反应是报错并停止执行后续的语句,而replace into语句可以实现强制插入。

文章目录

  • 一、replace into 语句简介
    • 1.1 基本用法
    • 1.2 使用set语句
  • 二、注意事项
    • 2.1 替换时必须要有主键或唯一索引
    • 2.2 替换时无法引用旧行的数据

一、replace into 语句简介

insert into语句在插入数据时如果遇到主键或唯一键冲突时,其反应是报错并返回。而如果你想强制插入,即遇到键值冲突时使用最新的数据替换原数据,则可以用replace into来代替insert into语句。

1.1 基本用法

先创建一张测试表,并插入2条数据:

create table mytab(
id int not null auto_increment primary key,
source varchar(16),
value int default 999);insert into mytab values(1, 'insert', 100),(2,'insert', 200);
table mytab;

在这里插入图片描述

下面用insert into语句插入2条数据,这里主键id=2出现了冲突,语句会执行失败:

insert into mytab values(2, 'insert', 200), (3, 'insert', 300);
table mytab;

在这里插入图片描述

将insert关键字替换为replace,当出现主键或唯一键冲突时,MySQL会先将表中冲突的数据删除,然后再插入,即隐式的帮你做了一个delete操作:

replace into mytab values(2, 'replace', 200), (3, 'replace', 300);
table mytab;

在这里插入图片描述
这里插入了2行数据,但是返回结果显示 3 rows affected,即是删除了1行,插入2行,共影响3行数据。同时Duplicates:1,显示有1行数据出现了重复。

1.2 使用set语句

replace into 还可以set语句用来指定每个列的值,这里更新id为1的行:

replace into mytab set id=1, source='set', value=101;
table mytab;

在这里插入图片描述

对于set中未指定的列,会被替换为默认值(这里不指定value的值,则其被设置成默认值999):

replace into mytab set id=1, source='set';
table mytab;

在这里插入图片描述

二、注意事项

2.1 替换时必须要有主键或唯一索引

replace into 发生替换时必须要检测到主键或唯一索引冲突,否则它的行为就和普通的insert into相同,我想把id为1的行value值设置为100,但仅引用source列,而通过source列无法判定冲突:

replace into mytab set source='set', value=100;
table mytab;

在这里插入图片描述
所以最终语句并没有像我预想的那样发生替换,而是插入了一行新数据。

2.2 替换时无法引用旧行的数据

如果我想在发生冲突时在原数据的基础上进行更新,这种场景replace into语句是无法做到的,因为在插入发生之前旧数据已经被删除了,所以是无法引用旧数据的,这里尝试将id=2的数据value值+1:

replace into mytab set id=2, source='plus 1', value=value+1;
table mytab;

在这里插入图片描述
可以看到最终结果并不是预想的201,而是1000。这是因为value=value+1,运算时无法引用旧值,而是引用了默认值。如果想实现冲突时在原数据上更新的效果,可以通过insert into … on duplcate key update语句实现。

最后提一句,replace into语句是MySQL对标准SQL的扩展,在其他RDBMS中可能并不适用。


文章转载自:

http://fmxFd0dt.wgkqq.cn
http://8INTlk0w.wgkqq.cn
http://nMekgd2s.wgkqq.cn
http://bUDjF3g5.wgkqq.cn
http://OZ7aXK1f.wgkqq.cn
http://kUsUuMMt.wgkqq.cn
http://zgpFf36Q.wgkqq.cn
http://sp90kuyC.wgkqq.cn
http://8K27RMdr.wgkqq.cn
http://J9xJSqzE.wgkqq.cn
http://0UmI7cig.wgkqq.cn
http://w3oWihpS.wgkqq.cn
http://guXi9R3q.wgkqq.cn
http://dQfPfjiS.wgkqq.cn
http://uOmIOkme.wgkqq.cn
http://mKKDqTt7.wgkqq.cn
http://E8P9EC13.wgkqq.cn
http://QJhBtISb.wgkqq.cn
http://dWNlbEkj.wgkqq.cn
http://U4YUMcy6.wgkqq.cn
http://A8DRDIhL.wgkqq.cn
http://WCzwjpDB.wgkqq.cn
http://DupGIA0M.wgkqq.cn
http://bLCD2aGU.wgkqq.cn
http://dGY77QLV.wgkqq.cn
http://B3LZIatn.wgkqq.cn
http://mYwn8RFK.wgkqq.cn
http://vhvSsLPD.wgkqq.cn
http://l7tfBnNu.wgkqq.cn
http://5EVtRrtb.wgkqq.cn
http://www.dtcms.com/wzjs/746198.html

相关文章:

  • tp5网站开发逻辑架构自助建站是什么意思
  • 浙江省建设银行网站浅谈网站建设的目的和意义
  • 西安专业网站开发联系电话东营做网站哪家好
  • 白云做网站SEO上海做网站的月薪
  • 网站规划与建设模板专业建站推荐
  • 网站链接设计小城镇建设网站的观点
  • 网站如何做seo的动画设计就业方向和发展前景
  • 网页ui设计网站济宁网站运营策略
  • 衡阳网站定制网站站点
  • 国际设计师网站有哪些1小时前俄乌战况消息
  • 怎么看到网站开发时间网站建设成本
  • 网站建设续费是那些驻马店网站建设熊掌号
  • 八角网站建设旅游网站设计说明
  • 成都cms建站52麻将官方网站做代理
  • 哪个网站做免费小程序商城网站建设需要多少钱
  • 团建网站建设wordpress阿里云建站
  • 自己做的网站能上传吗国内营销策划公司排名
  • 设计素材网站酷p搜狗识图
  • 做盗版小说网站赚钱嘛云南建设厅网站首页
  • 长春网站制作企业做网站的必要
  • 怎样做分销网站百度联盟添加网站
  • 网站的推广一般有什么方式便宜购 网站建设
  • 云南省城市建设培训中心网站上海公司注册地址可以是住宅吗
  • 北京规划网站网站建设招聘需求
  • 百度推广代理怎么加盟电子商务沙盘seo关键词
  • 照明公司网站制作公司网络组建方案设计
  • 做网站什么系统简单网站建设案例收费吗
  • 马鞍山做网站的公司78做网站的公司怎么转型
  • 网站制作对公司的作用优秀seo外包平台
  • html手机网站条形码生成器在线制作图片