MySQL事务、JDBC总结

本文介绍了JDBC中事务管理的基本概念与实现方法,并详细解释了如何通过JDBC进行批量处理来提高数据库操作效率。
 

一,     概括

在实际的应用中,很少只局限于对单表进行操作,通常会涉及多表操作。例如银行的取款操作,它至少需要两个步骤——首先进行取款操作,取款成功后更改账户金额;其次记录日志,记录此次取款的时间及金额等。这两个步骤是需要同时成功才算完成取款交易的。要完成上述的需求就需要借助于JDBC的事务管理和批量处理。

所谓事务:是指一组原子操作(一组SQL语句执行)的工作单元

这个工作单元中的所有原子操作在进行期间,与其他事务隔离,免于因数据来源的交相更新而发生混乱,事务中的所有原子操作要么全部执行成功,要么全部失败。

二,     创建JDBC的事务主要分以下步骤:

a)       设置事务的提交方式为非自动提交:conn.setAutoCommit(false); 

b)      将需要添加事务的代码放在try、catch块中:
try {
           //需要添加事务的业务代码
} catch (SQLException e) {
           ...
}

在try块内添加提交操作,表示操作无异常,提交事务:conn.commit();   //正常流程,提交事务

在catch块内添加回滚事务,表示操作出现异常,撤消事务:conn.rollback();   //发生异常,撤消事务

设置事务提交方式为自动提交:conn.setAutoCommit(true);  //自动提交事务

三,JDBC批量处理

•         Statement的execute()等方法一次只能执行一条SQL语句,如果同时有多条SQL语句要执行的话,可以使用addBatch()方法将要执行的SQL语句加入进来,然后执行executeBatch()方法,这样就可以在一次方法调用中执行多条SQL语句,以提高执行效率。

•         为了保证这一批语句要么全部成功,要么全部失败,应该把批处理放置在事务中进行。

•         使用PreparedStatement也可以进行批处理

简单地说,JDBC可做三件事:与数据库建立连接、发送 SQL 语句并处理结果。

•         对获得Connection对象进行封装

–       将数据库的配置信息写到一个属性文件中,然后用IO流去获取,当需要修改数据库连接的时候只要改动配置文件即可。

–       在src下新建属性文件jdbc.properties,添加如下内容:

•         driver=com.mysql.jdbc.Driver

•         url=jdbc:mysql://localhost:3306/test

•         username=root

•         password=root

•         对关闭JDBC资源类的封装

–       新建DbClose.java类,添加方法关闭结果集对象、语句对象、连接对象。

–       在执行增加、删除、修改的时候可以使用代码关闭连接:DbClose.close(Statement stmt, Connection conn);

–       在执行查询之后使用如下代码关闭连接:DbClose.close(ResultSet rs, Statement stmt, Connection conn);

四,     实例

      private Connection conn;

      private PreparedStatement pstmt;

      private ResultSet rs;

 

      /* 操作插入 */

      public boolean insert(Student entity) {

           /* 第一步:声明返回结果变量 */

           boolean flag = false;

           try {

                 /* 第二步:获取连接对象 */

                 conn = JdbcUtil.getConnection();

                 /* 第三步:定义sql语句 */

                 String sql = "insert into student(name,sex,resume,image) values(?,?,?,?)";

                 /* 第四步:根据sql语句创建预处理对象 */

                 pstmt = conn.prepareStatement(sql);

                 /* 第五步:为站位符赋值 */

                 int index = 1;

                 pstmt.setObject(index++, entity.getName());

                 pstmt.setObject(index++, entity.getSex());

                 pstmt.setObject(index++, entity.getResume());

                 // pstmt.setBinaryStream(parameterIndex, x)

                 pstmt.setObject(index++, entity.getImage());

                 /* 第六步:执行更新 */

                 int i = pstmt.executeUpdate();

                 /* 第七步:判断 */

                 if (i > 0) {

                      flag = true;

                 }

                 /* 第八步:释放资源 */

                 JdbcUtil.release(rs, pstmt, conn);

 

           } catch (SQLException e) {

                 // TODO Auto-generated catch block

                 e.printStackTrace();

           }

           /*    *****修改返回变量值 */

           return flag;

      }。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值