• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            大龍的博客

            常用鏈接

            統計

            最新評論

            java.sql.SQLException: 對只轉發結果集的無效操作: last

            java.sql.SQLException: 對只轉發結果集的無效操作: last 
            at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:111) 
            at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:145) 
            at oracle.jdbc.driver.BaseResultSet.last(BaseResultSet.java:81) 
            at com.ambow.upgrade.comm.UpGradeService.deleteOpr(UpGradeService.java:568) 
            at com.ambow.upgrade.comm.UpGradeService.loadData(UpGradeService.java:126) 
            at com.ambow.upgrade.comm.UpGradeService.exeUpgrade(UpGradeService.java:519) 
            at com.ambow.upgrade.comm.UpGradeService.main(UpGradeService.java:528) 



            JAVA代碼: 
            pstmt = sourceConn.prepareStatement(findSql); 
            pstmt.executeUpdate(); 
            rs = pstmt.executeQuery(); 
            rs.last();//移到最后一行 出錯代碼行 
            int rowCount = rs.getRow(); //得到當前行號,也就是記錄數 
            rs.beforeFirst(); //還要用到記錄集,就把指針再移到初始化的位置 


            出錯原因見這里: 
            Java代碼  收藏代碼
            1. http://www.cnblogs.com/mingal/archive/2007/03/07/666373.html  
            2.   
            3. 因為初學,所以,在建立Statement時使用默認參數。導致在使用執行rs.last()時,產生“java.sql.SQLException:對只轉發結果集的無效操作:last”的異常。  
            4. 最后在建立Statement時加入相關參數,就可以解決了。  
            5. 操作查詢結果集的過程中出現異常  
            6.    
            7. 出現異常的語句: rs.last();  
            8.    
            9. 異常的詳細信息:對只轉發結果集的無效操作: last  
            10.    
            11. 解決辦法:  stat = conn.createStatement();  
            12.          改為 stmt=conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); 就可以了  
            13.    
            14. 分析: 異常出現于移動結果集的指針時,原因是在生成statement對象的時候提供的參數不同  
            15. 無參數的那個方法使用的是默認參數,statement執行后得到的結果集類型為 ResultSet.TYPE_FORWARD_ONLY.這種類型的結果集只能通過rs.next();方法逐條讀取,使用其他方法就會報異常. 如果想執行一些復雜的移動結果集指針的操作就要使用其他參數了  
            16. 順便簡單介紹一下各個參數:  
            17. ResultSet.TYPE_FORWARD_ONLY   (略)  
            18. ResultSet.TYPE_SCROLL_INSENSITIVE  雙向滾動,但不及時更新,就是如果數據庫里的數據修改過,并不在ResultSet中反應出來。  
            19. ResultSet.TYPE_SCROLL_SENSITIVE  雙向滾動,并及時跟蹤數據庫里的更新,以便更改ResultSet中的數據。  
            20. ResultSet.CONCUR_READ_ONLY  只讀取ResultSet  
            21. ResultSet.CONCUR_UPDATABLE  用ResultSet更新數據庫  



            修改后的代碼: 
            pstmt = sourceConn.prepareStatement(findSql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); 
            pstmt.executeUpdate(); 
            rs = pstmt.executeQuery(); 
            rs.last();//移到最后一行 
            int rowCount = rs.getRow(); //得到當前行號,也就是記錄數 
            rs.beforeFirst(); //還要用到記錄集,就把指針再移到初始化的位置

            posted on 2011-06-12 23:21 大龍 閱讀(732) 評論(0)  編輯 收藏 引用

            久久亚洲av无码精品浪潮| 国产一级做a爰片久久毛片| 久久精品成人一区二区三区| 久久久精品人妻无码专区不卡| 亚洲精品高清一二区久久| 亚洲精品蜜桃久久久久久| 欧美日韩中文字幕久久伊人| 热99re久久国超精品首页| 亚洲国产精品成人AV无码久久综合影院| 亚洲va久久久噜噜噜久久男同 | 性欧美丰满熟妇XXXX性久久久| 成人国内精品久久久久一区| 人人狠狠综合88综合久久| 7777久久亚洲中文字幕| 亚洲&#228;v永久无码精品天堂久久 | 久久久久亚洲精品中文字幕| 亚洲欧美伊人久久综合一区二区 | 亚洲精品乱码久久久久久蜜桃| 少妇久久久久久久久久| 久久久久九国产精品| 久久99精品国产麻豆| 影音先锋女人AV鲁色资源网久久| 麻豆精品久久精品色综合| 久久精品国产久精国产思思| 中文字幕无码久久久| 欧美精品福利视频一区二区三区久久久精品| 久久久国产乱子伦精品作者| 久久精品人人做人人爽电影| 婷婷久久综合九色综合九七| 国产福利电影一区二区三区,免费久久久久久久精 | av国内精品久久久久影院| 一本色道久久综合狠狠躁篇| 久久国产精品一区| 99久久国产热无码精品免费久久久久| 亚洲国产精品无码久久一区二区| 亚洲欧美日韩久久精品| 亚洲精品乱码久久久久久不卡| 欧美一级久久久久久久大片| 色偷偷91久久综合噜噜噜噜| 亚洲精品高清一二区久久| 亚洲国产一成久久精品国产成人综合 |