一个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所有记录,此次脚本执行会话会被挂起,直到程序中的事务结束,而如果长时间没有停止事务,脚本执行因会话超时而停止,而在超时之前停止事务,则sql脚本继续执行,并会影响新插入的users记录。如果此时我向users表insert另一条记录,也是可行的,只是autoincrement会在第一次insert的基础上加1的,尽管现在还查不到第一次insert的记录。

结果1:第一次insert执行后,第二次insert执行之前这段时间内,MySql仍会允许对users表的一些操作的,而这些操作可能会影响我第二次insert时所获得的外键值,所以上述第二次insert操作是不可行的。

疑问2:上述方法不可行,不过我可以在第二次insert时,使用select id from users where username = 'username',来获得生成的id值,不过在前述中,通过客户端是查不到事务未结束而已经新插入的记录的,但是在同一个会话中我可以得到吗?

测试2:按照设想修改代码,运行结果显示确确实实获取到了users的新id值。

你可能感兴趣的:(J2EE)