`
zjx2388
  • 浏览: 1336941 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

对只转发结果集的无效操作: last--这样的错误

    博客分类:
  • J2SE
阅读更多

package dao;

import java.util.ArrayList;

import datebase.DBOperException;
import datebase.DBSource;
import java.sql.*;

import struts.form.TestForm;
import vo.userVO;
import tool.Page;

public class userDAO {

String sql = null;

//控制分页的属性
int page = 1;
int maxPage = 1;

//最大记录数量
private int maxRecordNumber=0;

public int getMaxPage() {
return maxPage;
}

public int getPage() {
return page;
}

public void setMaxPage(int maxPage) {
this.maxPage = maxPage;
}

public void setPage(int page) {
this.page = page;
}

/**
* @return maxRecordNumber
*/
public int getMaxRecordNumber() {
return maxRecordNumber;
}

/**
* @param maxRecordNumber 要设置的 maxRecordNumber
*/
public void setMaxRecordNumber(int maxRecordNumber) {
this.maxRecordNumber = maxRecordNumber;
}

/**
*
* @param testForm FORM对象
* @param requestpage 被请求的页
* @param pageNum 每页的数量(显示)
* @return
* @throws DBOperException
*/
public ArrayList selectUSERBASICINFO(TestForm testForm,int requestpage,int pageNum) throws DBOperException{

//广告信息列表
ArrayList adlist = new ArrayList();

// 需要的数据库对象
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;

try {
//查询条件
sql = "select userid,userpassword,phone,email from userbasicinfo where sex=?";
// 得到连接
conn = DBSource.getConnection();
//pstmt = conn.prepareStatement(sql);修改之前的语句
pstmt = conn.prepareStatement(sql,
ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_READ_ONLY);//修改过的语句

pstmt.setString(1,testForm.getSex());
System.out.println(testForm.getSex());

//执行查询
rs = pstmt.executeQuery();

//得到最大的数量
int pageNumber = pageNum;

boolean last = rs.last();//将cursor移到最后
if(last){
int rowNumber = rs.getRow();//获取符合的数据条数

//设置列表中的显示数量
maxRecordNumber = rowNumber;

maxPage = rowNumber/pageNumber;
if(rowNumber % pageNumber > 0){
maxPage++;
}

}

//如果输入的页大于最大的页面,则选择最大的页面
if(requestpage >= maxPage){
page = maxPage;
}else{
this.page = requestpage;
}

//把查询到的历史信息组合成历史信息对象,然后添加到全部历史对象中
if(page > 1 && last){
rs.absolute(pageNumber * (page - 1));
}else if(page == 1 && last){
rs.beforeFirst();//将cursor移到初始状态
}
//把查询到的历史信息组合成历史信息对象,然后添加到全部历史对象中
int currentPosition = 0;

//把查找到的全部广告基本信息对象放到集合对象中
while(rs.next()&& currentPosition < pageNumber && last){
//创建一个VO对象???????????到底放while外面还是放while里面
userVO uservo= newuserVO();

uservo.setEmail(rs.getString("email"));
uservo.setPhone(rs.getString("phone"));
uservo.setUserid(rs.getString("userid"));
uservo.setUserpassword(rs.getString("userpassword"));


//把属性加入列表
adlist.add(uservo);
currentPosition ++ ;

}

} catch (SQLException ex) {
try {
conn.rollback();
} catch (SQLException e) {
e.printStackTrace();
}
ex.printStackTrace();
throw new DBOperException("数据库更新失败!");
} finally {
try {
// 关闭连接
rs.close();
pstmt.close();
conn.close();
} catch (SQLException ex1) {
ex1.printStackTrace();
}
}
//返回得到广告显示信息的列表
return adlist;
}
}

java.sql.SQLException: 对只转发结果集的无效操作: last
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:111)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:145)
at oracle.jdbc.driver.BaseResultSet.last(BaseResultSet.java:81)
at org.apache.tomcat.dbcp.dbcp.DelegatingResultSet.last(DelegatingResultSet.java:328)
at dao.userDAO.selectUSERBASICINFO(userDAO.java:86)
at struts.action.TestAction.execute(TestAction.java:54)
at org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:419)
at org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:224)
at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1194)
at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:432)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:709)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:252)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:173)
at tool.EncodeFilter.doFilter(EncodeFilter.java:42)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:202)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:173)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:178)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:126)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:105)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:107)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:148)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:856)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.processConnection(Http11Protocol.java:744)
at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:527)
at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:80)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:684)
at java.lang.Thread.run(Thread.java:595)
2008-1-22 20:07:28 org.apache.struts.action.RequestProcessor processException
警告: Unhandled Exception thrown: class datebase.DBOperException
2008-1-22 20:07:28 org.apache.catalina.core.ApplicationContext log
信息: null


产生错误代码行:
pstmt = conn.prepareStatement(sql);
boolean last = rs.last();
将pstmt = conn.prepareStatement(sql);
改为:pstmt = conn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);

ResultSet.TYPE_SCROLL_INSENSITIVE 双向滚动,但不及时更新,就是如果数据库里的数据修改过,并不在ResultSet中反应出来。
ResultSet.TYPE_SCROLL_SENSITIVE 双向滚动,并及时跟踪数据库里的更新,以便更改ResultSet中的数据。
ResultSet.CONCUR_READ_ONLY 只读取ResultSet 。
ResultSet.CONCUR_UPDATABLE 用ResultSet更新数据库 。

分享到:
评论

相关推荐

    jQuery中:last-child选择器用法实例

    理解并熟练运用`:last-child`选择器,能够帮助我们更高效地操作DOM(文档对象模型)。 `:last-child`选择器的语法结构相当简单,如下所示: ```javascript $:last-child ``` 这里的`$`代表jQuery的选择器,`:last...

    六年级英语(下册)词汇专练.doc

    【知识点详解】 这篇文档是针对小学六年级英语下册的词汇专练,涵盖了词组、单词及其比较级和过去式的翻译与变化。以下是详细的知识点: ...通过这样的训练,学生可以提高阅读、写作和口语表达能力。

    前端开源库-last-one-wins

    6. **性能优化**:last-one-wins可能考虑了性能优化,例如通过缓存结果来避免重复的异步操作,或者使用某种形式的节流或防抖策略来限制函数执行的频率。 在实际应用中,这个库可能适用于以下场景: - **数据获取**...

    选择器(css3/css2)

    这类选择器包括但不限于 `:first-child`、`:last-child`、`:nth-child()`、`:nth-last-child()`、`:nth-of-type()` 和 `:nth-last-of-type()` 等。 #### 三、具体选择器详解 ##### 1\. `:first-child` `:first-...

    PEP人教版五年级英语下学期期末全册复习资料.pdf

    - last: 最后的 - sound: 声音 - also: 也 - busy: 忙碌的 - need: 需要 - play: 玩耍 - letter: 信件 - when: 何时 - live: 居住 - after: 在...之后 - island: 岛屿 - start: 开始 - always: 总是 -...

    使用HTML开发商业网站-结构化伪类选择器课件.pptx

    这在处理一些只包含单一子元素的情况时特别有用,例如在某些布局中,可能需要对这样的元素应用特殊样式。 **示例代码:** ```css div:only-child { background-color: yellow; } ``` ### 4. :first-child 和 :...

    http协议-缓存控制:etag If-None-Match / Last-Modified If-Modified-Since

    本文将深入探讨两个关键的缓存机制:Etag与If-None-Match以及Last-Modified与If-Modified-Since。 1. Etag与If-None-Match: Etag(Entity Tag)是一种用于标识资源版本的机制。服务器在响应头中设置Etag,它通常是...

    HTML5/CSS餐厅练习.rar

    orange.small:last-of-type,apple.small:last-of-type 是orange.samll和apple.small元素的最后一个元素 第二十五关 bento:empty bento元素里没有包括额外元素 第二十六关 apple:not(.small) apple里没有组是.small...

    org.vaadin.addons.dcharts-widget-0.10.0-dcharts-widget-0.10.0.jar

    org.vaadin.addons.dcharts-widget-0.10.0-dcharts-widget-0.10.0.jar

    七年级英语下学期第一次月考试题(无答案) 冀教版 试题.doc

    这篇文档是针对七年级英语下学期的第...通过这样的试题,教师可以评估学生在词汇量、语法掌握和阅读理解等方面的能力,并针对学生的薄弱环节进行教学调整。同时,学生可以通过解答这些题目来巩固和提升自己的英语水平。

    Ofbiz数据库模型文档

    通过对“Ofbiz数据库模型文档”的深入解读,我们可以清晰地了解到Ofbiz系统中“Budget”和“BudgetAttribute”表的设计理念和实现细节。这不仅对于理解和使用Ofbiz系统具有重要意义,同时也为开发者提供了宝贵的...

    OFBiz数据模型

    ### OFBiz数据模型详解 #### 一、概述 在OFBiz框架中,数据模型是所有应用程序的核心组成部分之一,它...同时,通过对不同实体间的关系定义,实现了数据的有效关联和查询,为开发高效的应用程序提供了坚实的基础。

    HTML5&CSS3网页制作:结构化伪类选择器.pptx

    `:first-child`可以用于给列表项的第一项添加特别样式,`:last-child`则可以用于在列表或其他元素结尾添加特殊效果。 `:nth-child(n)`和`:nth-last-child(n)`选择器允许你选择父元素中的第n个子元素或倒数第n个子...

    ECMALL数据库字典[归类].pdf

    ECMALL是一款电子商务平台软件,其数据库字典包含了多个关键表,用于管理平台的各种功能,如广告、管理员操作、用户、文章、商品分类、品牌、购物车、评论、配置等。下面将对这些核心概念进行详细说明。 1. **ecm_...

    memcached 1.2.6 1.2.5

    Last updated: 25 Jul 2009 Files libevent 1.4.12 Happily, libevent will now build out of the box on Windows (at least with VC2003 and VC2008, I haven't tested others). I don't like their projects ...

    用css完成根据子元素不同书写样式的方法

    &:last-child:nth-child(1) { // 相关样式 } } 很好理解:div下面即是最后一个元素也是第一个元素不就是只有一个子元素吗? 用css选择器匹配只有两个子元素 div{ &:nth-last-child(2):nth-child(2) { } } 依样...

    使用css属性:nth-child(n)匹配选择第n个子元素

    而`:nth-last-child(n)`和`:nth-last-of-type(n)`则是从后向前计算,选取倒数第n个子元素。 在实际应用中,`:nth-child(n)`经常与伪类如`:hover`、`:active`和`:focus`结合使用,以实现更精细的交互效果。同时,`:...

    RDF-Generator-HTTP:RDF-Generator-HTTP 的只读发布历史

    my $ua = LWP::UserAgent-&gt;new;...use RDF::Trine qw(iri);my $g = RDF::Generator::HTTP-&gt;new(message =&gt; $response, graph =&gt; iri('http://example.org/graphname'), blacklist =&gt; ['Last-Modified', '

    CSerialPort串口类更新版2014-01-10

    ** LAST MODIFICATION 12-11-1997 ** ** AUTHOR Remon Spekreijse ** ** ************************************************************************************ ** author: mrlong date:2007-12-25 ** ** 改进...

Global site tag (gtag.js) - Google Analytics