首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql技巧:如果记录存在更新如果不存在插入的三种处理方法

要求: 新增一个员工时,如果该员工已存在(以员工号f_emp_code作为判断依据),更新,否则插入。而且工资f_salary,更新时,不得低于原工资(即:工资只能涨,不能降)。...10007' , '新人' , '西安' , IF(1000 > f_salary , 1000 , f_salary)); replace into相当于,先检测该记录是否存在(根据表上的唯一键),如果存在...这个方法有一个很大的问题,如果记录存在,每次执行完,主键自增id就变了(相当于重新insert了一条),对于有复杂关联的业务场景,如果主表的id变了,其它子表没做好同步,会死得很难看。...但是有另外一个问题,如果这个表上有不止一个唯一约束,在特定版本的mysql中容易产生dead lock(死锁),见网友文章https://blog.csdn.net/pml18710973036/article

7.8K20
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL|优化案例两

如果只是创建 idx_a(a) ,sql请求通过索引 idx_a 访问 10w 条件记录,然后还要逐一匹配10w条记录中的status,找到符合 b=2 的记录。这个动作会导致慢查。...如果创建组合索引 idx_ab(a,b), sql请求通过索引 idx_ab 可以直接定位到1000条记录,无需额外的过滤,这样减少访问9900条记录的时间,提升查询速度。...索引本身是有序的,之所以产生 file sort 说明组合索引中存在字段在索引中存储的顺序和order by 字段的顺序不一致,不是严格正相关导致 MySQL 根据结果重新排序。...mysql> select * from x where a=2 order by b; +----+------+------+ | id | a | b | +----+------+...mysql> select * from x where a>=1 and a<3 order by b; +----+------+------+ | id | a | b | +---

41810

MySQL并发事务访问相同记录

同时 锁机制 也为实现MySQL的各个隔离级别提供了保证。 锁冲突 也是影响数据库 并发访问性能 的一个重要因素。所以锁对数据库而 言显得尤其重要,也更加复杂。...读-读情况 读-读 情况,即并发事务相继 读取相同的记录 。读取操作本身不会对记录有任何影响,并不会引起什么 问题,所以允许这种情况的发生。...写-写情况 写-写 情况,即并发事务相继对相同的记录做出改动。 在这种情况下会发生 脏写 的问题,任何一种隔离级别都不允许这种问题的发生。...比如MySQL在 REPEATABLE READ 隔离级别上就已经 解决了 幻读 问题。 并发问题的解决方案 怎么解决 脏读 、 不可重复读 、 幻读 这些问题呢?

1.1K30

MySQL多实例安装(相同版本)

本文以MySQL5.7为例,介绍在同一台机器下如何安装多个MySQL实例。...环境:RHEL 6.5 + MySQL 5.7 1.单实例MySQL安装 2.多实例MySQL配置 3.多实例MySQL初始化 4.多实例MySQL常用管理命令 1.单实例MySQL安装 先来看下MySQL5.7...mysql shell> cd mysql shell> mkdir mysql-files shell> chown mysql:mysql mysql-files shell> chmod 750...2.多实例MySQL配置 下面来看下多实例MySQL配置,如果需要安装多实例在同一台机器上,主要4个地方的配置需要区分:端口(Port)、数据目录(datadir)、socket文件、server-id...Ge28k psPWYuk/)8=j <8Pk#rxteaqx 修改密码,我这里测试环境为了方便统一设置密码为123,如果是生产环境切记要设计符合客户要求的密码安全策略: [root@jystdrac2

1.8K30

MySQL隐式转换案例一

隐式转换,可以说是关系型数据库SQL优化中很隐秘的问题,之前碰到过很多和他相关的案例, 《隐式转换的替代方案不是万能的》 《Oracle、SQL Server和MySQL的隐式转换异同》 《见识一下SQL...《从隐式转换案例,来挖掘开发人员的技能提升》 《浅谈显式转换和隐式转换》 《隐式转换的案例场景》 《一次有意思的错选执行计划问题定位》 数据和云的这篇文章《SQL优化——隐式字符编码转换》介绍了MySQL...MySQL中我们知道, 如果对索引字段做函数操作,可能会破坏索引值的有序性,因此优化器就决定放弃走树搜索功能。 隐式类型转换也会导致放弃走树搜索。...因为类型转换等价于在条件字段上使用了函数,例如, 假设tradeid字段有索引,且为varchar类型, mysql> select * from tradelog where tradeid=110717...; 等价于, mysql> select * from tradelog where CAST(tradid AS signed int) = 110717; 下面来看看隐式字符编码转换导致的一个慢SQL

50540

记录不存在插入,存在更新 → MySQL 的实现方式有哪些?

,不存在执行插入   针对这个需求,我们有哪些实现方式?...首先尝试插入数据到表中,如果发现表中已经有此行数据(根据主键或者唯一索引判断)先删除此行数据,然后插入新的数据,否则直接插入新数据 replace 语句会返回一个数,表示受影响的行的数目,该数是被删除和被插入的行数的和...我们来想一下这个问题:如果 master 库崩了,我们会怎么做?...,存在更新 , MySQL 还提供了另外一种方言实现: INSERT ......,否则则是插入   例如,如果 列 a 被声明为唯一且包含值 1,则以下两条语句具有类似的效果   但是这两条 SQL 的效果并不完全相同,我们以 t_ware_last_delivery_price

2.1K10
领券