java_271_JDBC_事务概念_ACID特点_隔离级别_提交commit_回滚rollback_练习

事务
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
package java_271_JDBC_事务概念_ACID特点_隔离级别_提交commit_回滚rollback_练习;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
/**

  • 测试事务的基本概念和用法
    */
    public class Demo06 {
    public static void main(String[] args) {
    //声明
    Connection conn =null;
    PreparedStatement ps1 =null;
    PreparedStatement ps2 =null;
    try {
    //加载驱动类
    Class.forName(“com.mysql.jdbc.Driver”);
    //连接数据库
    conn = DriverManager.getConnection(
    “jdbc:mysql://localhost:3306/testjdbc?useSSL=false&characterEncoding=UTF-8”,“root”,“www4152276”); //characterEncoding 字符编码
    conn.setAutoCommit(false);//JDBC系统默认事务是自动提交的true ;false手动提交

     	//事务1
     	ps1 = conn.prepareStatement("insert into t_user(username,pwd) values(?,?)");//注意导入的包名
     	ps1.setObject(1, "张三");
     	ps1.setObject(2, "123456");
     	ps1.execute();//执行
     	System.out.println("插入一个用户,张三");
     	try {
     		Thread.sleep(6000);//处理异常
     	} catch (InterruptedException e) { 
     		// TODO Auto-generated catch block
     		e.printStackTrace();
     	}//休眠一定时间
     	
     	//事务2
     	ps2 = conn.prepareStatement("insert into t_user(username,pwd) values(?,?)");//注意导入的包名
     	ps2.setObject(1, "李四");
     	ps2.setObject(2, "12345 ");
     	ps2.execute();//执行
     	System.out.println("插入一个用户,李四");
     	conn.commit();//提交
     	
     } catch (ClassNotFoundException e) {  
         	e.printStackTrace();  
         	try {
     			conn.rollback();//回滚
     		} catch (SQLException e1) {
     			
     			e1.printStackTrace();
     		}
     } catch (SQLException e) {   
     		e.printStackTrace();   
     } finally {
     	//关闭遵循先进后关原则;一定要分开关闭,这样出现异常不影响后面的程序执行
     	if(ps2!=null){
     		try {
     			ps2.close();//关闭
     		} catch (SQLException e) {
     			e.printStackTrace();
     		}
     	}
     	if(ps1!=null){
     		try {
     			ps1.close();//关闭
     		} catch (SQLException e) {
     			e.printStackTrace();
     		}
     	}
     	if(conn!=null){
     		try {
     			conn.close();//关闭
     		} catch (SQLException e) {
     			e.printStackTrace();
     		}
     	}
     } 
    

    }
    }
    //--------------------------结果-----
    在这里插入图片描述
    在这里插入图片描述
    //-----------------------如果一个事务错误----------------------
    在这里插入图片描述
    //--------------------测试结果-------------------
    清空表
    在这里插入图片描述
    控制台 第二个报异常
    在这里插入图片描述
    数据库写入失败;2个SQL语句在一个事务里面 要么同时写入成功,要么同时失败;回滚到之前的状态
    在这里插入图片描述

activation-1.1.jar antlr-2.7.2.jar aopalliance-1.0.jar aopalliance.jar apache-commons-codec-1.4.jar asm-3.3.1.jar asm-3.3.jar asm-commons-3.3.jar asm-tree-3.3.jar axis2-java2wsdl-1.0.jar builder-0.6.2.jar c3p0-0.9.1.2.jar cglib-2.2.2.jar cglib-2.2.jar classworlds-1.1.jar com.springsource.com.mchange.v2.c3p0-0.9.1.2.jar com.springsource.net.sf.cglib-2.2.0.jar com.springsource.org.aopalliance-1.0.0.jar com.springsource.org.aopalliance-sources-1.0.0.jar com.springsource.org.apache.commons.logging-1.1.1.jar com.springsource.org.aspectj.weaver-1.6.8.RELEASE.jar commons-beanutils-1.8.0.jar commons-beanutils-1.8.3.jar commons-chain-1.2.jar commons-codec-1.10.jar commons-codec-1.9.jar commons-collections-3.1.jar commons-collections-3.2.jar commons-dbcp-1.2.jar commons-digester-2.0.jar commons-fileupload-1.2.jar commons-fileupload-1.3.2.jar commons-fileupload-1.3.jar commons-io-1.3.1.jar commons-io-2.0.1.jar commons-io-2.2.jar commons-lang-2.4.jar commons-lang3-3.1.jar commons-lang3-3.2.jar commons-logging-1.1.1.jar commons-logging-1.1.3.jar commons-logging-1.2.jar commons-logging-api-1.1.jar commons-validator-1.3.1.jar core-0.6.2.jar cxf-api-2.7.4.jar cxf-rt-bindings-soap-2.7.4.jar cxf-rt-bindings-xml-2.7.4.jar cxf-rt-core-2.7.4.jar cxf-rt-databinding-jaxb-2.7.4.jar cxf-rt-frontend-jaxws-2.7.4.jar cxf-rt-frontend-simple-2.7.4.jar cxf-rt-transports-http-2.7.4.jar cxf-rt-ws-addr-2.7.4.jar cxf-rt-ws-policy-2.7.4.jar cxf-site-export-1.0-20130910.143757-9.jar dom4j-1.6.1.jar druid-1.0.12.jar dwr-1.1.1.jar ezmorph-1.0.6.jar fastjson-1.1.15.jar freemarker-2.3.19.jar freemarker-2.3.22.jar geronimo-javamail_1.4_spec-1.7.1.jar geronimo-jta_1.1_spec-1.1.1.jar google-collections-1.0.jar google-gxp-0.2.4-beta.jar gson-2.2.4.jar guava-r09.jar httpclient-4.4.jar httpcore-4.4.jar jackson-annotations-2.5.0.jar jackson-core-2.5.0.jar jackson-core-asl-1.9.2.jar jackson-databind-2.3.4.jar jackson-databind-2.5.0.jar jackson-mapper-asl-1.9.2.jar jackson-module-jaxb-annotations-2.1.0.jar jai_imag
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REaDME.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值