[转载自flywind63的blog]微软的sql server的jdbc驱动问题:ResultSet can not re-read row

转载 2004年09月23日 11:40:00
微软看到这个标题,肯定不高兴了。不过说实话,在商业应用中,很少有公司真正实用微软的那个什么com.microsoft.jdbc.sqlserver.SQLServerDriver。

    其实发现微软驱动的不足,也是很偶然的机会。在一次移植应用中,系统报告了[Microsoft][SQLServer JDBC Driver]ResultSet can not re-read row data for column之类的错误。为了解决这个错误,跟踪程序忙了大半天,也没有查出问题所在。只能确定在在rs.getString("XXX")的时候必然会出现错误(rs为ResultSet对象)。那么现在就模拟以下当时的环境:
    数据库表:TestTable
    表字段及类型:
         guid char(38)
         title varchar(100)
         content Text
         username varchar(20)
    查询sql语句:
         select guid,username,content,title from TestTable where····
    java代码:
         rs.getString("guid");
         rs.getBinaryStream("content");
         rs.getString("username");
    -----------------------------------------------------------

    上面那段代码,很不荣幸是。使用微软的驱动,必然会报错(就是上面说的那个错误)。如果你跟踪的话,必然是这一行:rs.getString("username")抛出错误。

    那么,如果你把rs.getString("username")和rs.getBinaryStream("content");位置互换以下,会怎么样呢。结果就是可以正常运行。

    为什么会出现这种情况呢,因为微软的驱动,在包含了blob或clob类型(就是Image和Text类型)的字段。那么就必须按照select顺序查询,且不支持重复查询。

   面对这种情况,只有更换驱动了。国外第三方的驱动很多,比如JSQLConnect,JTurbo等等。这些都是商用的,需要付费,不够有试用版本。如果希望有个免费的,可以在www.freetds.com上获取一个免费的(我没有测试过这个免费驱动,不知道是否会存在这种情况)。
 
有关最初的说明,可以参考[javasearch]
http://www.javaresearch.org/article/showarticle.jsp?column=2&thread=4278]
或[javaunion](很遗憾的是,javaunion已经不存在了)
http://www.javaunion.org/bbs/cgi-bin/topic.cgi?forum=1&topic=15516&show=0

    其实今天想说的这篇文档真的有些老了。早在曾经的javaunion还存在的时候就谈过这样的问题了。今天突然又贴出来,只是偶然间发现了数据库板块中的“SQLServer2000 JDBC驱动的完整安装及测试说明”这篇文档。我以为会有些什么值得参考的东东,结果大失所望(文章很适合入门型的参考,从这一点上写的还是可以的)。不过,拿来商业性应用中,就有些幼稚了。
    希望大家慎用或尽量不要用微软自带的sqlserver的jdbc驱动。
    如果有什么疑问,或有错误地方,请斧正。可以发邮件,相互交流。


作者:银狐999(james999)
信箱:james-fly@vip.sina.com

===============================================
接受blundblade兄弟的建议,补充如下:

(1)如果采用jdbc-odbc驱动,那么就必须按照查询顺序来一次读取(不论有没有image或text类型)
(2)如果采用微软提供的ms sql server jdbc driver,如果查询语句中,不存在image或text类型字段,那么可以按照无序获取
(3)如果采用微软提供的ms sql server jdbc driver,如果查询语句中,存在image或text类型字段,那么就必须按照顺序读取,否则就会报告Driver]ResultSet can not re-read row data for column之类的错误
(4)如果想不查询语句中有没有image或text类型字段,都可以不按照顺序获取,或重复获取。那么就必须更换驱动,改用第三方的。

JDBC 的ResultSet操作理解

原文链接:http://dev.csdn.net/develop/article/35/article/35/article/34/article/34/article/34/article/34/a...
  • u012514606
  • u012514606
  • 2014年09月14日 11:03
  • 879

关于java基础--SQL驱动及JDBC连接

一、SQL与JDBC 1,SQL驱动 步骤: (1)设置驱动包调用路径driver (2)设置调用的URL (3)设置用户名username (4)设置用户密码userpass (5)调用驱动包Cla...
  • yzjyhp
  • yzjyhp
  • 2015年07月22日 21:40
  • 1094

JDBC使用ResultSet卷动、更新数据

通常,我们在使用JDBC的ResultSet时,默认使用next()移动数据至下一个数据,然后使用getXXX()方法来获得数据,但是这样并不方便,比如在访问完一个数据项后,想向前或者向后、寻找第一条...
  • zhuxinquan61
  • zhuxinquan61
  • 2016年09月06日 17:07
  • 1187

JDBC返回结果集转Map集合

package com.tiantian.mybatis.test; import java.math.BigDecimal; import java.sql.Connection; import ...
  • yangzongzhuan
  • yangzongzhuan
  • 2015年05月04日 13:05
  • 4556

jdbc中ResultSet集的剖析

结果集是一个二维表格,行对应于一条记录,列对应于记录的属性; 结果集有一个游标(指针),初始位置在第一行的前边,也就是说没有指向任何行; 我们可以通过next()方法向下移动游标,next()的返...
  • xiaofeifeiloving
  • xiaofeifeiloving
  • 2014年07月31日 12:07
  • 449

数据库结果集ResultSet详解

这篇文章并没有给出如何使用ResultSet的具体例子,只是从ResultSet的功能性上进行了详细的讲述。希望这篇文章对大家理解ResultSet能够有所帮助。下面就是这篇文章的具体内容。  ...
  • u013046841
  • u013046841
  • 2014年08月19日 22:56
  • 3282

Connection、PreparedStatement、Statement、ResultSet是JDBC编程常用的接口,请分别简述它们的作用?

JDBC定义: JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的JavaAPI,可以为多种关系数据库提供统一访问,它由一组用Java语...
  • dingxingmei
  • dingxingmei
  • 2014年09月14日 16:09
  • 2197

将JDBC ResultSet解析为JSON格式

JSON (JavaScript Object Notation) is a lightweight data-interchange format.
  • u012607848
  • u012607848
  • 2015年11月26日 17:33
  • 3331

从零开始学JDBC--1.6 DQL--ResultSet的遍历方法

1.DQL代码 不同于前面的DML过程的是,将原来的sql语句改成DQL,并且调用statement的executeQuery() 方法执行查询,返回结果使用ResultSet 进行接收。Strin...
  • u014726937
  • u014726937
  • 2016年10月17日 17:30
  • 10806

[疯狂Java]JDBC:可滚动/可更新的ResultSet

1. 之前还有一个大问题没有解决:为什么ResultSet时刻都保持着跟Connection的绑定(Connection关闭ResultSet也被关闭)     1) 其实你可能猜到了,ResultS...
  • Lirx_Tech
  • Lirx_Tech
  • 2016年04月14日 15:48
  • 678
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[转载自flywind63的blog]微软的sql server的jdbc驱动问题:ResultSet can not re-read row
举报原因:
原因补充:

(最多只允许输入30个字)