热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

一张表中记录读取记录时游标定位的问题(rowSet.next())!~在线等...

设计描述:我想在从数据库中的一张表中读取记录。并且在每条记录前增加一个复选框,以求能够被选择(逻辑删除)的效果。如图:在JavaBean中使用for循环。在每条记录的最前方一个单元格(<t
设计描述:我想在从数据库中的一张表中读取记录。并且在每条记录前增加一个复选框,以求能够被选择(逻辑删除)的效果。如图:

在JavaBean中使用for循环。在每条记录的最前方一个单元格()里输出一个复选框。使用if判断语句 rowSet.next()布尔类型。问题也就出在这里:如果用next()方法,游标就会从表中的第二条记录读起,造成输出的记录少了第一条。请问这个问题怎样解决?

表test结构:

mysql> desc test;
+-------+---------------+------+-----+---------+-------+
| Field | Type          | Null | Key | Default | Extra |
+-------+---------------+------+-----+---------+-------+
| del   | enum('N','Y') | YES  |     | N       |       |
| id    | int(10)       | NO   | PRI | 0       |       |
| cname | varchar(20)   | YES  |     | NULL    |       |
+-------+---------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

JavaBean文件部分内容:
ShowRecordByPage.java
...
.....
.......
CachedRowSetImpl rowSet;              //用于存储ResultSet对象.
.......
....
..
 for(int i=1;i<=pageSize;i++)
    { str.append("");
       if(rowSet.next()){
         str.append("");
         str.append("");
            for(int k=1;k<=fieldnum;k++)
              {
               str.append(""+rowSet.getString(k)+"");
              }
               str.append("");}
     }
............
.....
..

JSP页面部分代码:
showByPages.jsp

.....


   默认状态客户ID客户名 //这里的这个复选框也就是表格里最左上角那个单元格里的复选框,没有用for循环控制输出.将来用JS脚本控制全选/不选
    //获取表中记录。


......


17 个解决方案

#1


for(int i=1;i <=pageSize;i++)
    { 
       if(rowSet.next()){
         str.append(" ");
         str.append("  ");
         str.append(" ");
            for(int k=1;k <=fieldnum;k++)
              {
               str.append(" "+rowSet.getString(k)+" ");
              }
         str.append(" ");}
     } 


如果不行就用可滚动纪录集吧

#2


引用 1 楼 yeecheng 的回复:
Java codefor(int i=1;i <=pageSize;i++)
    { 
       if(rowSet.next()){
         str.append(" ");
         str.append("  ");
         str.append(" ");
            for(int k=1;k <=fieldnum;k++)
              {
               str.append(" "+rowSet.getString(k)+" ");
              }
         str.append(" ")…

#3


用可滚动纪录集吧

#4


lz你算遇到好人了,这个问题我遇到过
解决方案1:请lz仔细检查程序,rs游标默认应该是在表的第一行之前,如果rs.next();肯定会走到第一条,由于lz说他走到了第2条,证明lz之前已经有个语句让游标向下移动了一个位置了,请仔细减产,我原先就是犯了这个错误.
解决方案2:调用这个方法:rs.relative(-1),让游标向前走一行,这样就ok了

#5


引用 4 楼 ilrxx 的回复:
lz你算遇到好人了,这个问题我遇到过 
解决方案1:请lz仔细检查程序,rs游标默认应该是在表的第一行之前,如果rs.next();肯定会走到第一条,由于lz说他走到了第2条,证明lz之前已经有个语句让游标向下移动了一个位置了,请仔细减产,我原先就是犯了这个错误. 
解决方案2:调用这个方法:rs.relative(-1),让游标向前走一行,这样就ok了


同意楼上说法,不是rs的问题

记得用rs.next();判断的话好像是会前进一条,建议直接用while(rs.next();)循环

#6


呵呵rs.relative(-1)确实是从第一条记录开始了输出了,但奇怪的是改后竟然少了2条记录。
rowSet.next()从第二条记录开始输出,一直到最后的那条记录。结果少了一条(第一条)记录。

引用 3 楼 zidasine 的回复:
用可滚动纪录集吧

离线结果集类CachedRowSetImpl继承了滚动记录集类ResultSet里的所有方法!~

#7


引用 5 楼 zhuyl_wind 的回复:
引用 4 楼 ilrxx 的回复:
lz你算遇到好人了,这个问题我遇到过  
解决方案1:请lz仔细检查程序,rs游标默认应该是在表的第一行之前,如果rs.next();肯定会走到第一条,由于lz说他走到了第2条,证明lz之前已经有个语句让游标向下移动了一个位置了,请仔细减产,我原先就是犯了这个错误.  
解决方案2:调用这个方法:rs.relative(-1),让游标向前走一行,这样就ok了 
同意楼上说法,不是rs的问题 
记得用rs.next();判断的话好像是会前进一条,建议直接用 while(rs.next() ;)循环 

呵呵!~结果更糟!~

#8


同意楼上意见
[rs游标默认应该是在表的第一行之前,如果rs.next();肯定会走到第一条,由于lz说他走到了第2条,证明lz之前已经有个语句让游标向下移动了一个位置了]
楼主贴出全部代码来看看

#9


(rs.next();)基础知识错误!~  或许兄弟手误。

#10


呵呵 ~ 好吧!贴出来一些重要的吧。8楼的兄弟可能有所不知,无论是在CSDN还是其他地方,你贴出来的代码越多,反而没什么
人回答你的问题。

package database.operation;
import java.sql.*;
import com.sun.rowset.CachedRowSetImpl;
public class ShowRecordByPage
{   int pageSize=0;                      //每页显示的记录数
    int pageAllCount=0;                   //分页后的总页数
    int showPage=1 ;                      //当前显示页 
    StringBuffer presentPageResult;       //显示当前页内容
    CachedRowSetImpl rowSet;              //用于存储ResultSet对象
    String databaseName="";               //数据库名称
    String tableName="";                  //表的名字
    String user=""       ;                //用户
    String password="" ;                  //密码 
    String field[]=new String[100]  ;     //field字段
    int fieldnum=0;
    public ShowRecordByPage()
    {  presentPageResult=new StringBuffer();
       try{  Class.forName("com.mysql.jdbc.Driver").newInstance();
          }
       catch(Exception e){
        System.out.println("加载驱动失败!~"+e);} 
    }
    public void setPageSize(int size)
    {  pageSize=size;
       fieldnum=0;
       String uri="jdbc:mysql://localhost:3306/deltest?useUnicode=true&characterEncoding=EUC_CN";
       try{  Connection con=DriverManager.getConnection(uri,user,password);
             DatabaseMetaData metadata=con.getMetaData();
             ResultSet rs1=metadata.getColumns(null,null,tableName,null);
             int k=0;
             while(rs1.next())
              { fieldnum++;
                field[k]=rs1.getString(4); //获取字段的名字
                k++;
              }
            Statement sql=con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,
ResultSet.CONCUR_READ_ONLY);
            ResultSet rs=sql.executeQuery("SELECT * FROM  test");
            rowSet=new CachedRowSetImpl();  //创建行集对象
            rowSet.populate(rs);
            con.close();                  //关闭连接 
            rowSet.last();
            int m=rowSet.getRow();    //总行数
            int n=pageSize;
            pageAllCount=((m%n)==0)?(m/n):(m/n+1);
           }
        catch(Exception exp){}
    }
    public int getPageSize()
    {  return pageSize;
    } 
    public int getPageAllCount()
    {  return pageAllCount;
    } 
    public void setShowPage(int n)
    {  showPage=n;
    }
    public int getShowPage()
    { return showPage;
    }
    public StringBuffer getPresentPageResult()
    {  if(showPage>pageAllCount)
          showPage=1;
       if(showPage<=0)
          showPage=pageAllCount;
       presentPageResult=show(showPage);
       return presentPageResult; 
    }
    public StringBuffer show(int page)
    {  StringBuffer str=new StringBuffer();

       try{  rowSet.absolute((page-1)*pageSize+1);
             for(int i=1;i<=pageSize;i++)
              { str.append("");
                if(rowSet.next()){
                
                str.append("");
                str.append("");
                 for(int k=1;k<=fieldnum;k++)
                  {
                    str.append(""+rowSet.getString(k)+"");
                  }
                str.append("");}
               
              }
          }
       catch(SQLException exp){}
       return str;
    }
   public void setDatabaseName(String s)
    {  databaseName=s.trim();
    }
    public String getDatabaseName()
    {  return databaseName;
    }
    public void setTableName(String s)
    {  tableName=s.trim();
    }
    public String getTableName()
    {  return tableName;
    }
    public void setPassword(String s)
    {  password=s.trim();;
    }
    public void setUser(String s)
    {  user=s.trim();
    }
    public String getUser()
    {  return user;
    } 
}

#11


public StringBuffer show(int page)
    {  StringBuffer str=new StringBuffer();

       try{  rowSet.absolute((page-1)*pageSize+1);
             for(int i=1;i<=pageSize;i++)
              { str.append("");
                if(!rowSet.isAfterLast()){
                
                str.append("");
                str.append("");
                 for(int k=1;k<=fieldnum;k++)
                  {
                    str.append(""+rowSet.getString(k)+"");
                  }
                str.append("");}

                rowSet.next();
              }
          }
       catch(SQLException exp){}
       return str;
    }


试试

#12


public StringBuffer show(int page)
    {  StringBuffer str=new StringBuffer();

       try{  rowSet.absolute((page-1)*pageSize+1);
             for(int i=1;i<=pageSize;i++)
              { str.append("");
                if(!rowSet.isAfterLast()){
                
                str.append("");
                str.append("");
                 for(int k=1;k<=fieldnum;k++)
                  {
                    str.append(""+rowSet.getString(k)+"");
                  }
                str.append("");
rowSet.next();

}
                
              }
          }
       catch(SQLException exp){}
       return str;
    }

#13


敢问lz一个问题,您贴的代码中这句rowSet.absolute((page-1)*pageSize+1);
如果传进来的page=1,游标定位到第一行,敢问在用rowSet.next()的时候是第几行?是不是应该在这句的后面加上一句让游标向上移动一行

#14


呵呵!~ 看看isAfterLast()方法的返回类型吧!

#15


引用 13 楼 ilrxx 的回复:
敢问lz一个问题,您贴的代码中这句rowSet.absolute((page-1)*pageSize+1); 
如果传进来的page=1,游标定位到第一行,敢问在用rowSet.next()的时候是第几行?是不是应该在这句的后面加上一句让游标向上移动一行

解决了!~真的非常感谢!~
 public StringBuffer show(int page){  
    StringBuffer str=new StringBuffer();
       try{  
          rowSet.absolute((page-1)*pageSize+1);
           rowSet.relative(-1);
          ......
          ..

#16


不客气

#17


来晚了一步啊 
只是感觉楼主没贴出的代码里应该有引发问题的部分而已

可以把相关内容都贴出来,如果整个代码太长的话

推荐阅读
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • CentOS 6.5安装VMware Tools及共享文件夹显示问题解决方法
    本文介绍了在CentOS 6.5上安装VMware Tools及解决共享文件夹显示问题的方法。包括清空CD/DVD使用的ISO镜像文件、创建挂载目录、改变光驱设备的读写权限等步骤。最后给出了拷贝解压VMware Tools的操作。 ... [详细]
author-avatar
朱小小喵喵_972
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有