土成 2017-02-03 07:16 采纳率: 83.3%
浏览 15814
已采纳

java中事务未提交,但是在update之后再select为什么会得到update之后的结果?

想知道为什么会这样?
代码如下:


public static void main(String[] args) {
        String dbName = "F:/firstdb";

        String driver = "org.apache.derby.jdbc.EmbeddedDriver";

        String protocol = "jdbc:derby:";

        try{
            Class.forName(driver).newInstance();
            System.out.println("Loaded the appropriate driver");

            Connection conn = DriverManager.getConnection(protocol + dbName + ";");
            System.out.println("Connected to and created database " + dbName);

            conn.setAutoCommit(false);
            Statement stat = conn.createStatement();
            String command = "update my_test set NAME='1234' where ID='03'";
            stat.executeUpdate(command);
            //conn.rollback();


            PreparedStatement state = conn.prepareStatement("select * from my_test", ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);

            ResultSet rs = state.executeQuery();

            int i = 1;
            while(rs.next()){
                if(i < 4){
                    System.out.printf(rs.getString(1) + " ");
                    System.out.printf(rs.getString(2) + " ");
                    System.out.printf(rs.getString(3) + " ");
                    System.out.printf(rs.getString(4) + "\n");
                    i++;
                }else{
                    rs.relative(-2);
                    System.out.println("finally");
                    System.out.printf(rs.getString(1) + " ");
                    System.out.printf(rs.getString(2) + " ");
                    System.out.printf(rs.getString(3) + " ");
                    System.out.printf(rs.getString(4) + "\n");
                    break;
                }
            }

        }catch(Exception e){
            e.printStackTrace();
        }
    }

结果如下:

 Loaded the appropriate driver
Connected to and created database F:/firstdb
01 男 10 LiSi
02 女 20 ZhangSan
03 男 40 1234
finally
02 女 20 ZhangSan

如果把update相关语句注释掉,那么结果如下:

 Loaded the appropriate driver
Connected to and created database F:/firstdb
01 男 10 LiSi
02 女 20 ZhangSan
03 男 40 123
finally
02 女 20 ZhangSan
  • 写回答

8条回答 默认 最新

  • AProMonkey 2017-02-03 09:17
    关注

    你这是没有明白什么叫事务,在数据库事务是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行,这是一种机制,用以维护数据库的完整性。在你这个事务单元中存在两个操作,一个是update,一个是select;你前面的update执行成功了,再执行select肯定能够查询到前面update的数据,因为你是在一个单元中。但是另外一个事务(即另一个单元)则不能select到这个update的数据,因为你update的数据还没提交,只在该单元中有效

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(7条)

报告相同问题?