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

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条)

报告相同问题?

悬赏问题

  • ¥15 C#调用python代码(python带有库)
  • ¥15 矩阵加法的规则是两个矩阵中对应位置的数的绝对值进行加和
  • ¥15 活动选择题。最多可以参加几个项目?
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能
  • ¥15 Source insight编写代码后使用CCS5.2版本import之后,代码跳到注释行里面
  • ¥50 NT4.0系统 STOP:0X0000007B