rs.next 问题

if(rs.next()){rs.first();}else{dos.writeUTF("false");}while(rs.next()){Stringresult=r... if(rs.next())
{
rs.first();
}
else
{
dos.writeUTF("false");
}

while(rs.next())
{
String result = rs.getString(3)+rs.getString(4)+rs.getString(5)+rs.getString(6);
dos.writeUTF(result);
}

我想取完整的数据,但是根据上面的编码,第一组数据都取不了

麻烦高手指教!!

请详细给出方法代码,谢谢了
展开
 我来答
wyb68712653
推荐于2017-12-15 · TA获得超过271个赞
知道答主
回答量:172
采纳率:0%
帮助的人:154万
展开全部
楼上所得有道理。
rs是结果集。查询出的记录是一个列表,初始时指针指向的是第一条记录之前的。
每rs.next()一次指针都会向后移动一位,指向下一条记录。
如果没有设置结果集的参数,那么正常情况下结果集都只能往下走,不能退回,也就是rs.next()后,是不能再指向已经指过的记录了,但是如果设置了
conn.createStatement(rs.TYPE_SCROLL_INSENSITIVE,rs.CONCUR_READ_ONLY);
那么就可以使用rs.first()、rs.last()等方法自己移动结果集指针,但是这种特性(可滚动结果集)是需要数据库支持的,好在现在大部分数据库都是支持的。
======================
翻译下你的代码:
if(rs.next()){ //判断结果集rs是否有记录,并且将指针后移一位
rs.first();//如果有记录,再将指针指向第一条(需要设置结果集类型)
}
else
{
dos.writeUTF("false"); //否则输出false
}

while(rs.next()) //如果rs有记录,那么迭代,但是因为上边已经使用rs.next将指针指向第一条记录了,那么此时初始时再next时实际上指向的是第二条记录。
{
String result = rs.getString(3)+rs.getString(4)+rs.getString(5)+rs.getString(6); //取记录结果值
dos.writeUTF(result);
}

=========================
问题已经说了,上边已经取了rs.next,指针指向的是第二条记录。所以可以这样试试:
if(rs.hasNext()) //判断结果集是否有记录,此方法只是判断,指针不移动
{
..... //做需要做的事情
}
else
{
dos.writeUTF("false");
}

while(rs.next())
{
String result = rs.getString(3)+rs.getString(4)+rs.getString(5)+rs.getString(6);
dos.writeUTF(result);
}
晴天宝贝天枰
2018-03-31 · TA获得超过2328个赞
知道小有建树答主
回答量:15
采纳率:0%
帮助的人:2387
展开全部

如果说是"判断结果集里有没有值" 那么用if(rs.next) 。while是用来做循环输出的 换句话说 就是"如果结果集里还有值" 没有则停止循环 这个一般在JSP做显示用。

1、rs = stmt.exeQuery(sql)后,rs肯定不会为null,注意,是rs对象不会为null,而不是其包含的result。

2、既然rs不会为null,所以在rs = stmt.exeQuery(sql)后,使用while(rs.next())或if(rs.next())时就不用判断rs != null。

3、rs.next时,游标最先是指向第一条记录前的位置,所以第一次rs.next后,游标指向的正好是第一条记录(如果有的话)。

4、要判断rs的结果是否为空,只要使用一次rs.next方法就行了,如果它返回为false,则证明rs的结果为null。

rs是结果集。查询出的记录是一个列表,初始时指针指向的是第一条记录之前的。每rs.next()一次指针都会向后移动一位,指向下一条记录。

如果没有设置结果集的参数,那么正常情况下结果集都只能往下走,不能退回,也就是rs.next()后。

conn.createStatement(rs.TYPE_SCROLL_INSENSITIVE,rs.CONCUR_READ_ONLY)。

可以使用rs.first()、rs.last()等方法自己移动结果集指针,但是这种特性(可滚动结果集)是需要数据库支持的,好在现在大部分数据库都是支持的。

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
20105200lq
2010-11-01
知道答主
回答量:3
采纳率:0%
帮助的人:0
展开全部
你好,一般首先声明 ResultSet rs=null;
rs是用于保存数据库查询到的结果集
UserInfo userinfo=null;
--这中间是对数据库查询的操作
if(rs.next){
userinfo=new UserInfo();
}
在这里UserIn不能首先实例化 要在rs.next有结果的时候在实例化,不然当你返回值的时候一直都有值,只是并未被赋值而已,我以前就遇到类似的问题,我也是个新手,如有说错的地方就一笑而过吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友1c1bd3deb
2010-11-01 · 超过35用户采纳过TA的回答
知道答主
回答量:114
采纳率:0%
帮助的人:133万
展开全部
程序中运用.last()和.first()方法,需要在创建statement时修改参数
smt = conn.createStatement(rs.TYPE_SCROLL_INSENSITIVE,rs.CONCUR_READ_ONLY);
另外,在代码中先rs.first(),再rs.next(),然后再取结果,会从查询结果的第2条记录开始取值
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式