Oracle中COMMIT的用法
Oracle中COMMIT语句的用法
COMMIT
在Oracle中,COMMIT语句可以用来提交当前事务的所有更改。提交后,其他用户将能够看到您的更改。
SQL语言分类
SQL语言分为五大类:
- DDL(数据定义语言) - Create、Alter、Drop 这些语句自动提交,无需用Commit提交。
- DQL(数据查询语言) - Select 查询语句不存在提交问题。
- DML(数据操纵语言) - Insert、Update、Delete 这些语句需要Commit才能提交。
- DTL(事务控制语言) - Commit、Rollback 事务提交与回滚语句。
- DCL(数据控制语言) - Grant、Revoke 授予权限与回收权限语句。
解释
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命令提交。