对于select、update、insert,在项目开发中的使用顺序:
在项目开发中经常会遇到很多需要修改对某某条件下的数据进行修改或者判断数据是否存在,存在则修改不存在则插入的,对于这样的逻辑,必须有一个SQL优先级的概念,update\insert的优先级必须高于select,要使用update或者insert来进行逻辑控制而不是select,否则就极容易出现高并发下的数据安全问题;
通过update控制逻辑是否执行,update会自动加上行锁,这样就可以保证并发的安全;
通过insert控制逻辑是否执行,首先对于要插入的表字段建立唯一unique,这样重复插入就会报异常,判断是否有异常来控制逻辑;
select也可以进行控制,需要通过添加for update,进行行锁来保证并发安全,对于select的for update需要对where条件后的字段建立索引;