发布网友 发布时间:2022-04-13 17:25
共9个回答
热心网友 时间:2022-04-13 18:55
先插入再查询在事务内部的SELECT语句可以查询到数据,但是回滚后,不能查询到数据。先删除再查询。
在同一个事务中,数据需要保证一致性,也就是说,在当前的事务中,删除了就是看不到了,插入了就是多了一条数据。
但这些操作都是在当前事务内部的。对于外界是隔离的。如果我们开启事务插入一条数据,还没有提交,这时新开一个事务,去查询数据,是发现不了未提交数据的。
先插入再更新控制台打印的sql语句mybatis会将两条执行语句在同一个sqlSession中执行。先删除再查询控制台打印的sql语句。
热心网友 时间:2022-04-13 20:13
可以查询到,以下是Oracle的存储过程测试代码,游标返回了一行数据2,热心网友 时间:2022-04-13 21:47
能查到的,错误回答还能得最佳答案也是醉了。只不过事务没走完的情况下你用其他工具去数据库查是没有的。代码中查询是有你之前新增的数据的 你可以理解为预备操作,数据都已经新增出来了,只是还没commit掉热心网友 时间:2022-04-13 23:39
同一个事务内的所有操作可以理解为同一把锁,所以无论insert或者update的内容都可以被这个事务内的select读出来。其他的事务能不能读到,要看数据库的事务隔离等级。热心网友 时间:2022-04-14 01:47
java中在同一db下先插入一条数据未commit,在执行查询语句是可以查到的,db使用的是jdbc,亲测是可以的,忘采纳热心网友 时间:2022-04-14 04:11
ssm框架,在一个失误中在批量加入数据后,在查时,sum()处理的数据查不出热心网友 时间:2022-04-14 06:53
你在同一个事务里面进行插入查询操作不行吧,查不到数据的。
事务(Transaction)是访问并可能更新数据库中各种数据项的一个程序执行单元(unit)。事务通常由高级数据库操纵语言或编程语言(如SQL,C++或Java)书写的用户程序的执行所引起。
并用形如begin transaction和end transaction语句(或函数调用)来界定。事务由事务开始(begin transaction)和事务结束(end transaction)之间执行的全体操作组成。
原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。
一致性(consistency)。事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。
隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。
持久性(rability)。持续性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。
热心网友 时间:2022-04-14 09:51
你在同一个事务里面进行插入查询操作不行吧,查不到数据的。热心网友 时间:2022-04-14 13:05
不可以的,一般的事务规则中的查询是查不到未commit的数据的