<%@ page contentType="text/html; charset=gb2312"%> JSP 2.0 + ORACLE 9i 下高效率分页的一个例子
网站公告:   ◆北天JAVA技术网热情为java爱好者服务,本网内容包括JAVA(JSP、servlet、EJB、webservice、j2ee、javabean、应用服务器、JavaScript),数据库(MYSQL、SQL Server、Sybase、Oracle、DB2、数据库综合知识),设计研究(设计模式、Struts、Spring、Hibernate、设计框架、设计综合知识),WEB2.0新技术(主要介绍AJAX),以及各种技术的入门、实例、例子等等,欢迎各位多来坐坐!◆  诚邀各位JAVA爱好者加盟!◆  本网站内容丰富,更新快,保证每周20篇以上!  
加入收藏
设为首页
联系站长
承接项目
  相关资源:网站首页 | 免费培训学院 | 技术论坛 | JAVA聊天室 | 作家专栏 | 开发工具 | 认证考试 | 会员俱乐部
  JAVA技术初学者园地 | jsp与servlet | javascript | Java源代码 | EJB | web service | 应用服务器 | JAVA综合知识
  设计研究设计模式 | 设计框架 | Struts | Spring | Hibernate | 开源项目 | 面向对象设计 | 设计综合知识
  数 据 库MYSQL | SQL Server | Sybase | Oracle | DB2 | Informix | Access | 数据库综合知识
  其他资源:AJAX新技术 | 网站开发 | ERP软件 | OA办公软件 | 商业智能BI | 开发综合知识 | 承接项目 | 项目试用

 
 
JSP 2.0 + ORACLE 9i 下高效率分页的一个例子
     发布者: 发布时间:2006-05-07


import java.sql.Connection;
import java.sql.SQLException;
import javax.sql.DataSource;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;

public class DatabaseConn
{

public DatabaseConn()
{
}

public static synchronized Connection getConnection()throws Exception
{
Connection conn = null;
try
{
Context initCtx=new InitialContext();
Context envCtx=(Context)initCtx.lookup("java:comp/env");
DataSource ds=(DataSource)envCtx.lookup("jdbc/jspdev");
return ds.getConnection();
}
catch(SQLException e)
{
throw e;
}
catch(NamingException e)
{
throw e;
}
}
}




package com.cwbnig;

import java.sql.*;
import java.util.Vector;

public class OperateDB
{
private Connection conn=null;
private Statement stmt=null;
PreparedStatement pstmt=null;
CallableStatement cstmt=null;
private ResultSet rs=null;
private ResultSetMetaData rsmd=null;
private String strsql="";

public OperateDB()
{
try
{
conn = DatabaseConn.getConnection();
}
catch (Exception e)
{
System.out.println("Error:com.cwbnig.OperateDB:Structure Method");
}
}

public Connection getConnection() throws SQLException
{
return this.conn;
}

public ResultSet executeQuery(String sql) throws SQLException
{
stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);
return stmt.executeQuery(sql);
}

public ResultSet listDataFromMSSQL(int curpage,int pagesize,String tablename,String sid,String con,String order) throws SQLException
{
int SELECTNUM=(curpage-1)*pagesize+1;
if(order.equalsIgnoreCase("asc"))
{
String min="SELECT MAX("+sid+") AS id FROM (SELECT TOP "+SELECTNUM+" "+sid+" FROM "+tablename+" ORDER BY "+sid+" ASC) tbl";

strsql="SELECT TOP "+pagesize+" * FROM "+tablename+" WHERE "+sid+" >="+min+con+" ORDER BY "+sid+" ASC";
}
else
{
String max="SELECT MIN("+sid+") AS id FROM (SELECT TOP "+SELECTNUM+" "+sid+" FROM "+tablename+" ORDER BY "+sid+" DESC) tbl";

strsql="SELECT TOP "+pagesize+" * FROM "+tablename+" WHERE "+sid+" <="+max+con+" ORDER BY "+sid+" DESC";
}
return this.executeQuery(strsql);
}

public ResultSet listDataFromMySQL(int curpage,int pagesize,String tablename,String sid,String con,String order) throws SQLException
{
int SELECTNUM=(curpage-1)*pagesize;
if(order.equalsIgnoreCase("asc"))
{
strsql="SELECT * FROM "+tablename+con+" ORDER BY "+sid+" ASC LIMIT "+SELECTNUM+","+pagesize;
}
else
{
strsql="SELECT * FROM "+tablename+con+" ORDER BY "+sid+" DESC LIMIT "+SELECTNUM+","+pagesize;
}
return this.executeQuery(strsql);
}

public ResultSet listDataFromOracle(int curpage,int pagesize,String tablename,String sid,String con,String order) throws SQLException
{
int SELECTNUM=(curpage-1)*pagesize+2;
if(order.equalsIgnoreCase("asc"))
{
String min="SELECT MAX("+sid+") AS SID FROM (SELECT "+sid+" FROM "+tablename+" WHERE ROWNUM <"+SELECTNUM+" ORDER BY "+sid+" ASC) TBL";
strsql="SELECT * FROM "+tablename+" WHERE "+sid+" >=("+min+") AND ROWNUM <"+(pagesize+1)+con+" ORDER BY "+sid+" ASC";
}
else
{
String max="SELECT MIN("+sid+") AS SID FROM (SELECT "+sid+" FROM "+tablename+" WHERE ROWNUM <"+SELECTNUM+" ORDER BY "+sid+" DESC) TBL";
strsql="(SELECT * FROM "+tablename+" WHERE "+sid+" <=("+max+") ORDER BY "+sid+" DESC)TBL2";
strsql="SELECT * FROM "+strsql+" WHERE ROWNUM<"+(pagesize+1)+con;
}
return this.executeQuery(strsql);
}

public Vector getDataFromMSSQL(int curpage,int pagesize,String tablename,String sid,String con,String order) throws Exception
{
Vector v=new Vector();
rs=this.listDataFromMSSQL(curpage,pagesize,tablename,sid,con,order);
rsmd=rs.getMetaData();
int colnum=rsmd.getColumnCount();
while(rs.next())
{
Object[] obj=new Object[colnum];
for(int i=0;i<colnum;i++)
{
obj[i]=new String(this.getCol(rs,rsmd.getColumnType(i+1),i+1));
}
v.add(obj);
}
stmt.close();
rs.close();
conn.close();
return v;
}

public Vector getDataFromMySQL(int curpage,int pagesize,String tablename,String sid,String con,String order) throws Exception
{
Vector v=new Vector();
rs=this.listDataFromMySQL(curpage,pagesize,tablename,sid,con,order);
rsmd=rs.getMetaData();
int colnum=rsmd.getColumnCount();
while(rs.next())
{
Object[] obj=new Object[colnum];
for(int i=0;i<colnum;i++)
{
obj[i]=new String(this.getCol(rs,rsmd.getColumnType(i+1),i+1));
}
v.add(obj);
}
stmt.close();
rs.close();
conn.close();
return v;
}

public Vector getDataFromOracle(int curpage,int pagesize,String tablename,String sid,String con,String order) throws Exception
{
Vector v=new Vector();
rs=this.listDataFromOracle(curpage,pagesize,tablename,sid,con,order);
rsmd=rs.getMetaData();
int colnum=rsmd.getColumnCount();
while(rs.next())
{
Object[] obj=new Object[colnum];
for(int i=0;i<colnum;i++)
{
obj[i]=new String(this.getCol(rs,rsmd.getColumnType(i+1),i+1));
}
v.add(obj);
}
stmt.close();
rs.close();
conn.close();
return v;
}

public String getCol(ResultSet rs,int type,int colNum)throws Exception
{
String ret="";
switch(type)
{
case(1):ret=rs.getString(colNum);break;
case(2):ret=rs.getString(colNum);break;
case(4):ret=String.valueOf(rs.getInt(colNum));break;
case(5):ret=String.valueOf(rs.getInt(colNum));break;
case(6):ret=String.valueOf(rs.getFloat(colNum));break;
case(8):ret=String.valueOf(rs.getDouble(colNum));break;
case(12):ret=rs.getString(colNum);break;
default:ret="not know";
}
return ret;
}

public Object[] getColName(String tablename)throws Exception
{
stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);
rs=stmt.executeQuery("SELECT * FROM "+tablename+" WHERE ROWNUM<2");
rsmd=rs.getMetaData() ;
int colnum=rsmd.getColumnCount();
Object[] obj=new Object[colnum];
for(int i=0;i<colnum;i++)
{
obj[i]=rsmd.getColumnName(i+1);
}
return obj;
}

public int getRowCount(String tablename) throws SQLException
{
stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);
strsql="SELECT COUNT(*) AS COUNT FROM "+tablename;
rs=stmt.executeQuery(strsql);
if(rs.next())
{
return rs.getInt(1);
}
else
{
return 0;
}
}

public int getRowCount(ResultSet rs) throws SQLException
{
int rowCount = 0;
rs.last();
rowCount = rs.getRow();
rs.beforeFirst();
return rowCount;
}

public int executeUpdate(String sql) throws SQLException
{
stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);

return stmt.executeUpdate(sql);
}

public int[] executeUpdateBatch(String[] sqls) throws SQLException
{
conn.setAutoCommit(false);
stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
try
{
for (int i = 0; i < sqls.length; i++)
{
stmt.addBatch(sqls[i]);
}
int[] updateCounts=stmt.executeBatch();
conn.commit();
conn.setAutoCommit(true);
return updateCounts;
}
catch (SQLException e)
{
conn.rollback();
throw e;
}
}

public PreparedStatement prepareStatement(String sql) throws SQLException
{
pstmt = conn.prepareStatement(sql);
return pstmt;
}

public CallableStatement callableStatement(String sql) throws SQLException
{
cstmt = conn.prepareCall(sql);
return cstmt;
}

public void setAutoCommit(boolean s) throws SQLException
{
conn.setAutoCommit(s);
}

public void commit() throws SQLException
{
conn.commit();
}

public void rollback() throws SQLException
{
conn.rollback();
}

public void close() throws SQLException
{
if (stmt != null)
{
stmt.close();
stmt = null;
}
if (conn != null)
{
conn.close();
conn = null;
}
}
}



<%@ page contentType="text/html; charset=gb2312" language="java" errorPage="errorinfo.jsp"%>
<html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>testOracle</title>
</head>
<body>
<jsp:useBean id="operatedb" scope="page" class="com.cwbnig.OperateDB"/>
<%
Object[] obj=null;
obj=operatedb.getColName("TBL_STRUCTS");
for(int temp=0;temp<obj.length;temp++)
{
out.println(obj[temp]);
}

out.println("<br>");

java.util.Vector v=operatedb.getDataFromOracle(1,10,"TBL_STRUCTS","SID","","desc");
java.util.Enumeration e=v.elements();
while(e.hasMoreElements())
{
obj=(Object[])e.nextElement();
for(int i=0;i<obj.length;i++)
{
out.println(obj[i]);
}
out.print("<br>");
}
%>
</table>
<br>
<a href="testOracle.do?forward=bdgk">testOracle.do?forward=bdgk</a>
</body>
</html>

(转载文章请保留出处:北天JAVA技术网(www.java114.com))
 
更多精彩文章:
JSP与Servlet
Jsp 服务器resin的url重定向的摸索
JSP环境准备
Servlet中如何捕获Session事件?
JSP利用组件实现文件上传的全攻略
编写 "纯HTML" jsp应用--学会使用 JSTL
 
最近评论:
        
冰封的往事!
wow power leveling,wow gold,wow power leveling,wow gold max(6676)
        
冰封的往事!
wow power leveling,wow gold,WoW Gold,wow gold max(8526)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(1469)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(4251)
        
标 题:   
内 容:   
 
                                  
 
免责声明:该文章由网友发表,如果对您造成侵权,请联系站长

首页 - 承接项目 - 网站地图 - 联系我们 -
版权所有北天JAVA技术工作室 ICP证号:粤ICP备06079815号