Oracle何时须要commit

DML语言,好比update,delete,insert等修改表中数据的须要commit;
DDL语言,好比create,drop等改变表结构的,就不须要写commit(由于内部隐藏了commit);html

 

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命令提交。数据库

http://blog.sina.com.cn/s/blog_53e731b70101qa6t.htmloracle

相关文章
相关标签/搜索