位置: 编程技术 - 正文

MySQL replace into 语句浅析(二)

编辑:rootadmin

推荐整理分享MySQL replace into 语句浅析(二),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

一 介绍

上一篇文章介绍了replace into的基本原理。本章内容通过一个例子说明 replace into 带来的潜在的数据质量风险,当涉及replace into操作的表含有自增主键时,主备切换后会造成数据覆盖等不一致的情况发生。

二 案例分析

在主库上操作此时检查主备库上t1的表结构都是一样的,AUTO_INCREMENT 都是2.此时检查主备库中t1 表结构,请注意AUTO_INCREMENT=4从库上t1的表结构 ,AUTO_INCREMENT=2

【分析】

MySQL replace into 语句浅析(二)

表t1的表结构 AUTO_INCREMENT=2 而主库上的t1表结构的AUTO_INCREMENT=4.原本replace操作是在自增主键的情况下,遇到唯一键冲突时执行的是delete+insert,但是在记录binlog时,却记录成了update操作,update操作不会涉及到auto_increment的修改。备库应用了binlog之后,备库的表的auto_increment属性不变。

三 风险点:

如果主备库发生主从切换,备库变为原来的主库,按照原来的业务逻辑再往下会发生什么&#;如果t1表本来就存在多条记录 ,主从切换之后,应用写新的主库则会发生主键冲突,这个留给各位读者自己测试一下。^_^

四 解决方法

推荐使用 insert into table values(,....) on duplicate key update 语法结构来解决业务需求。 来避免replace into 给含有自增主键的表带来主从不一致情况。

五 总结

由于replace into操作在遇到主键冲突的时候 会修改主键的值,所以如果业务逻辑强依赖自增ID,绝对不要用replace,普通环境也不建议这样用,因为replace into 操作可能会导致主键的重新组织.推荐使用 insert into table values(,....) on duplicate key update 来解决业务需求。

使用innodb_force_recovery解决MySQL崩溃无法重启问题 一背景某一创业的朋友的主机因为磁盘阵列损坏机器crash,重启MySQL服务时报如下错误:InnoDB:Readingtablespaceinformationfromthe.ibdfiles...InnoDB:Restoringpossiblehalf-writte

MySQL slave_net_timeout参数解决的一个集群问题案例 【背景】对一套数据库集群进行5.5升级到5.6之后,alter.log报warning异常。--::[Warning]StoringMySQLusernameorpasswordinformationinthemasterinforepositoryisnotsecur

MySQL Index Condition Pushdown(ICP)性能优化方法实例 一概念介绍IndexConditionPushdown(ICP)是MySQL5.6版本中的新特性,是一种在存储引擎层使用索引过滤数据的一种优化方式。a当关闭ICP时,index仅仅是dataaccess的一种

标签: MySQL replace into 语句浅析(二)

本文链接地址:https://www.jiuchutong.com/biancheng/347682.html 转载请保留说明!

上一篇:MySQL replace into 语句浅析(一)

下一篇:使用innodb_force_recovery解决MySQL崩溃无法重启问题(使用权资产)

  • 季度所得税计提
  • 车险 保险金额
  • 进销存工作流程
  • 会计软件每年都要付钱的吗
  • 财务会计制度名称一般是
  • 合同上怎么注明开具6%的含税普通发票
  • 打车发票丢了怎么办
  • 增值税纳税义务发生时间
  • 培训费没有发票怎么办
  • 红字发票冲红步骤
  • 资本公积与股东借款
  • 食堂非税收入怎么申报
  • 房地产企业预付账款为负数
  • 银行 委托收款
  • 国际货运运费的计算基础
  • 华为最新款手机2023款
  • mac怎么打出@符号
  • mac怎么访问路径
  • 怎么获得最新医学类指南
  • 销售净利率范围
  • 母公司对子公司减资
  • 免征的农资增值税怎么算
  • thinkphp saveall
  • 预付款无法收回账务处理
  • 写一段简单的自我介绍
  • 单位向员工出租房屋要交增值税吗
  • 电脑找不到u盘怎么解决
  • PHP:Memcached::flush()的用法_Memcached类
  • wordpress更改字体
  • 一亩地是多少平方?
  • 金融企业计提贷款利率
  • elipse左侧菜单栏显示
  • vue项目引入ts
  • php中自定义函数的语法格式
  • ChatGPT在热门行业的应用场景有哪些
  • New Bing怼人、说谎、PUA,ChatGPT已经开始胡言乱语了
  • sed多个命令匹配条件格式
  • 新公司建账会计科目
  • 小规模季报所得税不超多少不用交税
  • 小规模纳税人企业所得税2023
  • 税控盘全额抵扣政策
  • 去年的预提费用今年进来了怎么入账
  • 厂区道路算建筑面积吗
  • 事业单位以资产为准吗
  • 商誉的会计核算怎么核算
  • 在租赁公司贷款买的车绿本上会有我的名字吗
  • 财务费用和应付利息都在借方
  • 公司员工支出
  • 税控设备管理办法
  • 购进生产设备的进项税额抵扣政策
  • 成本类科目借贷规则
  • 查询存储过程中的文件
  • 创建的sql语句
  • Windows Server 2003网络负载均衡如何实现
  • linux网卡lo
  • 一键u盘安装系统
  • 怎么恢复被破坏的文件
  • linux安装.gz
  • linux用什么写c
  • Win10 Build 14279正式推送 更新后QQ可能会崩溃
  • 图形学实验报告总结
  • 记住密码自动登录 会更新登陆信息吗
  • 全网最全的小说阅读器
  • python标准库函数有哪些
  • cocos2dx schedule
  • jquery与ajax获取特殊字符实例详解
  • css onclick
  • PyCharm在win10的64位系统安装实例
  • 批处理获取本地连接名称
  • unity c#开发
  • unity坐标系转换
  • android开发环境搭建实验报告总结
  • 使用灭火器人要站在上风口还是下风口
  • js点击按钮实现登陆网页
  • javascript default
  • 袁野近照
  • 税务局监控个人账户流程
  • 2018建筑材料考试试题及答案河南卷
  • 在珠海可以做什么生意
  • 发票清单盖章样本图片
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设