PreparedStatement 以及事务的注意事项

a).PreparedStatement 可以进行批量操作,但是与Statement有一定的区别

       1.  Statement可以进行不同sql语句的批量操作
            即可以同时进行   crud  操作.

                String sql1=xxx;
                String sql2=xxx;
                String sql3=xxx;
                Statement statement=conn.createStatement();
                statement.addBatch(sql1)  ;
                statement.addBatch(sql2);
                statement.addBatch(sql3);

                statement.executeQuery(sql)
                or
            statement.executeUpdate(sql)

        2. PreparedStatement  不能执行不同的sql语句,  只能执行一条类型的sql语句,但是可以参数不同

            String sql="insert into table values(?,?,?,?,?)";
            PreparedStatement  pstm=conn.preparedStatement  (sql);
            pstm.setString(1,xx);
            pstm.setString(2,xx);
            pstm.setString(3,xx);
            pstm.setString(4,xx);
            pstm.addBatch();
            pstm.setString(1,xx);
            pstm.setString(2,xx);
            pstm.setString(3,xx);
            pstm.setString(4,xx);
           pstm.addBatch();

            pstm.executeQuery();
           or
            pstm.executeUpate();

b) 注意这些批量操作,应该使用开启事务

        开启事务:
        1.需要去看数据库是否支持事务,更换引擎为InnodDB
        2.有些版本的navicat有一个开启事务的按钮
        3.在Dao层中,可以使用conn.setAutoCommit(false)   默认为true,这里设置为false,可以阻止自动提交
        //在进行完操作后,应该手动提交
        conn.commit();
        //如果出错, 需要回滚事务,那么我们可以在catch中进行事务的回滚操作
            //首先判断conn是否关闭了 
            if(!conn.isClosed)
            {
                //没有关闭进行回滚
                    conn.rollback();
                //随你...
                    conn.setAutoCommit(true);
            }
posted on 2019-09-07 17:03  储宏庆 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/chq1024/p/11481808.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值