事务
要么都成功,要么都失败
ACID原则,保证事务的安全
原子性(Atomicity):原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。
一致性(Consistency):事务前后数据的完整性必须保持一致。
隔离性(Isolation):事务的隔离性是多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离。
持久性(Durability):持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。
开启事务 事务提交:commit() 事务回滚:rollback() 关闭事务
- JUNIT单元测试
依赖
<!--单元测试--> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> </dependency>
简单使用
@Test注解只有在方法上有效,只要加了这个注解的方法,就可以直接运行
import org.junit.Test; public class TestJdbc3 { @Test public void test(){ System.out.println("测试成功"); } }
成功是绿色的。失败是红色
- 搭建一个环境测试一个事务
package com.hxl.test; import com.sun.javaws.jnl.RContentDesc; import org.junit.Test; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class TestJdbc3 { @Test public void test() { //配置信息 String url = "jdbc:mysql://localhost:3306/jdbc?useUnicode=true&characterEncoding=utf-8"; String username = "root"; String password = "123456"; Connection connection = null; //1.加载驱动 try { Class.forName("com.mysql.jdbc.Driver"); //2.连接数据库 connection = DriverManager.getConnection(url, username, password); //3.通知数据库开启事务 false是开启 connection.setAutoCommit(false); String sql = "UPDATE account set money = money - 100 where name = '老大';"; connection.prepareStatement(sql).executeUpdate(); //制造错误 //int i = 1 / 0; String sql2 = "UPDATE account set money = money + 100 where name = '老二';"; connection.prepareStatement(sql2).executeUpdate(); //以上两条SQL都执行成功了,就提交事务! connection.commit(); System.out.println("success"); } catch (Exception e) { try { //如果出现异常,就通知数据库回滚事务 connection.rollback(); } catch (SQLException ex) { ex.printStackTrace(); } e.printStackTrace(); }finally { try { connection.close(); } catch (SQLException e) { e.printStackTrace(); } } } }
start transaction;#开启事务(必须要做的) UPDATE account set money = money - 100 where name = '老大'; #rollback必须要在commint之前才可以,如果在提交之后再回滚,是不会回来的 rollback; commit;
在上述的代码中如果我们开启了制造错误,运行是失败的,数据也不会改变。另外我们没有通知开启事务,那虽然会报错,但是数据库的数据发生了改变,这个我们需要注意一下。