预览加载中,请您耐心等待几秒...
1/6
2/6
3/6
4/6
5/6
6/6

在线预览结束,喜欢就下载吧,查找使用更方便

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

Java中的JDBC事务解析Java中的JDBC事务解析事务事务是一步或多步组成操作序列组成的逻辑执行单元,这个序列要么全部执行,要么则全部放弃执行。事务的四个特性:原子性(Atomicity)、一致性(Consistency)、隔离性(IsoIation)和持续性(Durability)原子性(Atomicity):事务应用最小的执行单元,不可再分。是事务中不可再分的最小逻辑执行体。一致性(Consistency):事务的执行结果,必须使数据库的从一个一致性的状态变到另一个一致性的状态。隔离线(IsoIation):各个事务的执行互不干扰,任意一个事务的内部操作对其他并发的事务,都是隔离的。也就是:并发执行的事务之间不能看到对方的中间状态,并发执行的事务之间不能互相影响。持续性(Durability):持续性也称为持久性(Persistence),指事务一旦提交,对数据所做的任何改变,都要记录到永久存储器中,通常就是保存在物理数据库中。通常数据库的事务涉及到的语句有:一组DML(DataMunipulationLanguage,数据操作语言)语句,这组DML语句修改后数据将保持较好的一致性;操作表的语句,如插入、修改、删除等;一个DDL(DataDefinitionLanguage,数据定义语言)语句,操作数据对象的语言,有create、alter、drop。一个DCL(DataControlLanguage,数据控制语言)语句,主要有grant、revoke语句。DDL和DCL语句最多只能有一个,因为它们都会导致事务的立即提交。当事务所包含的全部数据库操作都成功执行后,应该提交事务,使这些修改永久生效。事务提交有两种方式:显示提交和自动提交。显示提交:使用commit提交自动提交:执行DLL或DCL,或者程序正常退出当事务包含的任意一个数据库操作执行失败后,应该回滚(rollback)事务,使该事务中所作的修改全部失效。事务的回滚方式有两种:显示回滚和自动回滚。显示回滚:使用rollback自动回滚:系统错误或强行退出。事务并发处理可能的问题1、脏读(dirtyread):一个事务读取了另一个事务尚未提交的数据2、不可重复读(non-repeatableread):一个事务的操作导致另一个事务前后两次读到不同的数据3、幻读(phantomread):一个事务的操作导致另一个事务前后两次查询的结果数据量不同举例:事务A、B并发执行时:当A事务update后,B事务select读取到A尚未提交的数据,此时A事务rollback,则B读到的数据是无效的脏数据当B事务select读取数据后,A事务update操作更改B事务select到的数据,此时B事务再次读取该数据,发现前后两次的数据不一样当B事务select读取数据后,A事务或了一条满足A事务的select条件的记录,此时B事务再次select,发现查询到前次不存在的记录,或者前次的某个记录不见了JavaJDBC事务机制importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.PreparedStatement;importjava.sql.SQLException;publicclassJDBCTransaction{publicstaticfinalStringURL="com.mysql.jdbc.Driver";publicstaticfinalStringUSER="root";publicstaticfinalStringPASSWD="123456";publicstaticvoidjdbcTransaction(intid){Connectionconn=null;PreparedStatementpstmt=null;PreparedStatementpstmtquery=null;Stringupdatesql="更新sql";Stringquerysql="查询sql";try{Class.forName("com.mysql.jdbc.Driver");conn=DriverManager.getConnection(URL,USER,PASSWD);conn.setAutoCommit(false);//自动提交设置为false//执行更新操作pstmt=conn.prepareStatement(updatesql);pstmtupdate.executeUpdate();//执行查找操作pstmtquery=conn.prepareStatemen