一个Spring事务中,前后两次数据库操作的影响关系

有这么一个场景,在程序的service层的一个方法中有两次数据库访问操作(分两次调用不同dao的insert方法,一个dao只包含对一个数据表的操作方法),且都会改动数据。第一,往users表添加记录,id是autoincrement(MySql数据库)实现的;第二,向sms表插入记录,且sms表有一字段外键依赖users表的id。在该方法体添加了事务监控。

疑问1:我想在第二次的insert操作的sql语句(如insert into sms(userid, username,content) values((SELECT Auto_increment - 1 FROM information_schema.tables WHERE  table_name='users'  AND table_schema = DATABASE()),'username',  'content'));但是这样做的前提是我在插入users的记录后,要获取的是刚刚插入的users记录的id值,也就是在第二次insert前不会有其他对users表的修改操作。事务能做到这点吗?

测试1:断点达到第一次insert之后,第二次insert之前。于是在到达断点时,我在mysql客户端执行sql脚本,这时看不到第一次insert插入的users记录,但可以update已经存在的记录。然后update所有记录,此次脚本执行会话会被挂起,直到程序中的事务结

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值