几个线程同时进行事务A。。如果事务A里面有一个步骤1:是对某一个表某条固定记录进行更新操作的。。问题1:那是不是表行会被锁住,线程之间后一个必须等前一个提交事务才继续(“运行”还是“提交事务”)?事务A有一个步骤2:是对某个表进行INSERT记录的;
事务A提交前还有一个步骤3:是比较步骤2的数据,如果出现INSERT的记录超过要求,就回滚。。问题2:如果问题1的答案是提交事务,如果发生并发,步骤3这一步是不是没用了,检测不了?如果答案是运行,那可以防并发吗?问题3:如果问题2解决不了,是不是一定要在步骤2 INSERT记录前进行这个表的SELECT FOR UPDATE进行行锁?这应该可以解决并发了吧,有没人其它办法呀。希望有前辈指导一下,谢谢
解决方案 »
- PHP如何获取COM组件方法事件的返回值?
- centos 5.x 下 php 连接不了 mysql 单独访问 mysql 没有问题 高分求解
- 谁有好的邮件群发系统啊!(SMTP)
- php调用java url 带文件参数传输
- php 返回的xml信息前面多一串数字
- csv 乱码问题
- 关于“||”的问题?
- time和UNIX_TIMESTAMP如何统一?
- 帮帮菜鸟vtelsai
- PHP手机网站调用手机照相接口,拍照完成后上传,图片旋转了90度,求解决方法
- 如何解决socket在监听端口时,只有一个客户端能往端口上发数据
- mysql_fetch_array(): supplied argument is not a valid mysql result resource
Atomicity(原子性)
Consistency(稳定性,一致性)
Isolation(隔离性)
Durability(可靠性)离开了这个原则,就没有讨论的必要了
2,A满足条件则更新A如果1,2不是原子的,那么查询A和更新A中间会有其他操作修改A,怎么办?把1,2整体锁住就行了,for update是一种办法,尤其是innodb可以行锁,所以比直接lock table好用。
上边都不说了,这个问题是关键。 一定要for update锁住,你完全可以认为for update就是lock加锁,只有这样才能保证原子性,否则一个这样的事务真心没法原子性:
原子性:一个事务是一个不可分割的工作单位,事务中包括的操作要么都做,要么都不做。
我一直以为事务本身就有这种功能,而不是要去构造这样的环境如果1,2不是原子的,那么查询A和更新A中间会有其他操作修改A,怎么办?把1,2整体锁住就行了
我有点明白了,这个是保证 隔离性?谢谢你
我这样理解有没有问题:
例如有两个线程 A和B
线程A判断条件满足了,进行了INSERT的操作,但事务还没提交。
这个时候线程B拿到的数据还没有A INSERT的数据,所以也满足了条件
当线程A提交以后,B再提交 导致并发的情况
所以一定要锁住判断的条件。。