mysql下的高并发SQL编写逻辑注意事项

  对于select、update、insert,在项目开发中的使用顺序:

 在项目开发中经常会遇到很多需要修改对某某条件下的数据进行修改或者判断数据是否存在,存在则修改不存在则插入的,对于这样的逻辑,必须有一个SQL优先级的概念,update\insert的优先级必须高于select,要使用update或者insert来进行逻辑控制而不是select,否则就极容易出现高并发下的数据安全问题;


通过update控制逻辑是否执行,update会自动加上行锁,这样就可以保证并发的安全;

通过insert控制逻辑是否执行,首先对于要插入的表字段建立唯一unique,这样重复插入就会报异常,判断是否有异常来控制逻辑;

select也可以进行控制,需要通过添加for update,进行行锁来保证并发安全,对于select的for update需要对where条件后的字段建立索引;


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值