今天在PL/SQL中执行了一些insert语句,然后在应用中查询了一下,发现数据条数不对。mybatis打印的sql放在PL/SQL中执行结果是7条,应用中查询结果是6条。
刚开始以为是数据库或者mybatis缓存造成的。后来发现insert语句有一个没有commit。
PL/SQL中执行DML语句需要添加commit来提交事务。
DDL不需要commit。
如果不添加commit;PL/SQL有提示
绿色箭头是commit提交,红色是rollback回滚。
Oracle本地执行的sql不提交,本地查询是没问题的,但是应用和其他用户查询都是原来的数据
总结:
DML语言,比如update,delete,insert等修改表中数据的需要commit;
DDL语言,比如create,drop等改变表结构的,就不需要写commit(因为内部隐藏了commit);
DDL 数据定义语言:
create table 创建表
alter table 修改表
drop table 删除表
truncate table 删除表中所有行
create index 创建索引
drop index 删除索引
当执行DDL语句时,在每一条语句前后,oracle都将提交当前的事务。如果用户使用insert命令将记录插入到数据库后,执行了一条DDL语句(如create
table),此时来自insert命令的数据将被提交到数据库。当DDL语句执行完成时,DDL语句会被自动提交,不能回滚。
DML 数据操作语言:
insert 将记录插入到数据库
update 修改数据库的记录
delete 删除数据库的记录
当执行DML命令如果没有提交,将不会被其他会话看到。除非在DML命令之后执行了DDL命令或DCL命令,或用户退出会话,或终止实例,此时系统会自动
发出commit命令,使未提交的DML命令提交。