JDBC和sqlserver连接,查询的异常

faimry 2007-07-03 02:46:17
小弟以前是用mysql数据库的 ,现在的系统要求使用sqlserver 2000,

sql=select * from tablename
Statement stmt = cn.createStatement();
stmt.executeQuery(sql);

数据库操作就大概上面的,然后执行的话,就出现下面异常,不知道是什么原因,在mysql下就没有这样问题;
java.sql.SQLException: [TDS Driver]Illegal method's call for result set of type TYPE_FORWARD_ONLY.
...全文
201 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
faimry 2007-07-03
  • 打赏
  • 举报
回复
哦,是这样啊,多谢上面那位大哥了
jihanzhong 2007-07-03
  • 打赏
  • 举报
回复
字段也只能顺序取,比如字段顺序是 A,B,C
取了B,A就不能取了
faimry 2007-07-03
  • 打赏
  • 举报
回复
上面那大哥说 的
可以这样:stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);
来获得可以回头的记录结果集,我以前也使用过,当sql是select * from tableName ,要取的字段是所有的 * 的话,也会出现sql异常,也不知道是不是驱动的问题,我使用的驱动是:com.microsoft.jdbc.sqlserver.SQLServerDriver。,
mjwd0000() 说的,用用的驱动是jtds的驱动,可能就不存在这样的问题了


faimry 2007-07-03
  • 打赏
  • 举报
回复
sql是这样的:select * from userInfo where username='"+username+"' and userpassword='"+userpassword+"'"
Statement stmt = cn.createStatement();
rs=stmt.executeQuery(sql);

if(rs.next()){
///do something
}
应该不存在“记录取数据只能向前”如果要回头的话,就得在createStatement();设定参数了,
jihanzhong 2007-07-03
  • 打赏
  • 举报
回复
可以这样:stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);

来获得可以回头的记录结果集
jihanzhong 2007-07-03
  • 打赏
  • 举报
回复
记录取数据只能向前,不能回头,楼主回头了
mjwd0000 2007-07-03
  • 打赏
  • 举报
回复
贴段代码给你参考下,用的驱动是jtds的驱动
Connection con;
Statement stmt;
// ResultSet rs;
try{
Class.forName("net.sourceforge.jtds.jdbc.Driver");
DriverManager.registerDriver(new net.sourceforge.jtds.jdbc.Driver());
String dbUrl = "jdbc:jtds:sqlserver:" +
"//localhost:1433/test;user=sa;password=root";

con = java.sql.DriverManager.getConnection(dbUrl);
String sql="";
stmt = con.createStatement();
for(int i=0;i<100;i++){
sql="insert into Test1(id) values('"+i+"')";
stmt.executeUpdate(sql);
}

/**//*rs = stmt.executeQuery("SELECT * FROM Test1");
while(rs.next()){
System.out.println(rs.getString(1));
}*/

// rs.close();
stmt.close();
con.close();
}catch(Exception e){
System.out.println("error");
}
System.out.println("OK2");

62,623

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧