JAVA语言中的SQL语句
使用java语言查询数据库的时候SQL语句一直报错while(reSet.next()){out.println("<tr>");out.println("<td>"+r...
使用java语言查询数据库的时候SQL语句一直报错
while(reSet.next()){
out.println("<tr>");
out.println("<td>"+reSet.getInt(1)+"</td>");
out.println("<td>"+reSet.getString(2)+"</td>");
out.println("<td>"+reSet.getString(3)+"</td>");
out.println("<td>"+reSet.getInt(4)+"</td>");
out.println("</tr>");
}
reSet是得道的查询结果,是一个4列的一个表,在执行reSet.getString(2)这一条语句的时候抛出异常
java.sql.SQLException: Column Index out of range, 2 > 1.
请问怎么解决??谢谢~ 展开
while(reSet.next()){
out.println("<tr>");
out.println("<td>"+reSet.getInt(1)+"</td>");
out.println("<td>"+reSet.getString(2)+"</td>");
out.println("<td>"+reSet.getString(3)+"</td>");
out.println("<td>"+reSet.getInt(4)+"</td>");
out.println("</tr>");
}
reSet是得道的查询结果,是一个4列的一个表,在执行reSet.getString(2)这一条语句的时候抛出异常
java.sql.SQLException: Column Index out of range, 2 > 1.
请问怎么解决??谢谢~ 展开
展开全部
建议你检查下sql语句,个人认为应该是你的sql语句中只查询出一个结果,但是你却调用了ResultSet.getXXX(2)方法,导致超出边界异常
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
索引越界了.
试试把getString() 和前面的getInt()中的索引, 换成具体的数据库列名, 就会明白是在哪儿越界了.
试试把getString() 和前面的getInt()中的索引, 换成具体的数据库列名, 就会明白是在哪儿越界了.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个异常说明 你的数据其实只有一列 但是你一共取了四列 在你的程序运行到第二列时,就因为越界而抛出异常,后面的就没有再运行了,不然第三个 和第四个都是错的。你可以把你的取reset的sql语句发下么??
更多追问追答
追问
追答
不要用*来取,因为你并不知道你取出来的列的顺序到底是什么,而且你还用索引来获取reset里面的值。
有两个建议:
写SQL的时候,需要取什么值,就写什么列。强烈建议不要因为偷懒而用*来代替,一来,数据量大的时候,取数据慢,而来当你使用索引取值的时候,经常会发生写不知道的错误。
取resultSet里面的值,建议使用列名来取,而不要使用索引,这样写出来的程序,可读性较高,便于他人维护。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询