码迷,mamicode.com
首页 > 其他好文 > 详细

PreparedStatement 以及事务的注意事项

时间:2019-09-07 17:13:55      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:ack   tst   nod   int   query   dao层   自动提交   sed   应该   

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);
            }

PreparedStatement 以及事务的注意事项

标签:ack   tst   nod   int   query   dao层   自动提交   sed   应该   

原文地址:https://www.cnblogs.com/chq1024/p/11481808.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!