Oracle数据库管理、应用与开发(十一)

17.7结束事务

什么情况下代表事务的结束呢?

17.7.1 Commit 提交事务

事务处理语句commit用于提交用户的事务处理,使得用户对数据库已经执行的修改永久生效。

17.7.2 Rollback 回滚事务

回滚一个事务可以撤销在事务中所做的工作。当用户在事务中输入的SQL语句出现错误,或者用户最终决定放弃对数据库中数据的修改时,可能需要进行事务回滚。

回滚事务最简单的方法是,只使用ROLLBACK语句进行回滚。

//只读的案例
SQL> set transaction read only;
Transaction set
SQL> select * from users where username='mj';
USERNAME      PASSWORD      NAME             ADDRESS             ZIP
-------------------- -------------------- -------------------- -------------------- -------
mj                  redarmy          陈红军
SQL> update users set password='123' where username='mj';
update users set password='123' where username='mj'
ORA-01456: 不能在 READ ONLY 事务处理中执行插入/删除/更新操作
//脏读的案例
SQL> set transaction isolation level read committed;
Transaction set
SQL> select * from users where username='mj';
USERNAME      PASSWORD      NAME             ADDRESS             ZIP
-------------------- -------------------- -------------------- -------------------- -------
mj                  redarmy          陈红军
SQL> update users set password='123' where username='mj';
1 row updated
SQL> select * from users where username='mj';
USERNAME      PASSWORD      NAME             ADDRESS             ZIP
-------------------- -------------------- -------------------- -------------------- -------
mj                  123                 陈红军
SQL> rollback;

 

你可能感兴趣的:(oracle,sql,工作)