jsp分頁(yè)類---統(tǒng)一使用_JSP教程
推薦:解析Jsp常用技巧:圖片驗(yàn)證碼思路 : 圖片驗(yàn)證碼的實(shí)現(xiàn)主要的技術(shù)點(diǎn)是如何生成一個(gè)圖片。生成圖片可以使用java.awt包下的類來(lái)實(shí)現(xiàn)。我們先寫(xiě)一個(gè)簡(jiǎn)單的生成圖片的程序HelloImage.java。以下是代碼部分。 package com.vogoal.test; import java.awt.Color; import java.awt.Graphics; imp
一、建立數(shù)據(jù)庫(kù)分頁(yè)的類
package newsbean;
import java.sql.*;
public class DBConnection{
//這里使用ms jdbc
String sDBDriver = "com.microsoft.jdbc.sqlserver.SQLServerDriver";
//指定數(shù)據(jù)庫(kù)名/url
private final String url = "jdbc:microsoft:sqlserver://";
private final String serverName= "localsqlserver";
private final String portNumber = "1433";
private final String databaseName= "MyBusiDB";
//String sConnStr = "jdbc:microsoft:sqlserver://localsqlserver:1433;DatabaseName=ourcompany";
private final String dbUserName = "sa";
private final String dbPassword = "111111";
// Informs the driver to use server a side-cursor,
// which permits more than one active statement
// on a connection.
private final String selectMethod = "cursor";
Connection conn = null;
ResultSet rs = null;
Statement stmt = null;
//這三個(gè)參數(shù)用于記錄翻頁(yè)
int iRowCount = 0; //返回總行數(shù)
int iPageCount = 0; //返回總頁(yè)數(shù)
int iPage = 0;
public DBConnection(){
try
{
Class.forName(sDBDriver);
}
catch(ClassNotFoundException e)
{
System.err.println("DBConnection():" + e.getMessage());
}
}
//構(gòu)造一個(gè)連接字符串
private String getConnectionUrl(){
return url+serverName+":"+portNumber+";databaseName="+databaseName+";selectMethod="+selectMethod+";";
}
//================考慮在類中的分頁(yè)======================================
//內(nèi)部設(shè)置總條數(shù)..
private void setRowCount(int irowcount)
{
this.iRowCount = irowcount;
}
//返回內(nèi)部設(shè)置的總條數(shù)
public int getRowCount()
{
return this.iRowCount;
}
//內(nèi)部設(shè)置總頁(yè)數(shù)..
private void setPageCount(int ipagecount)
{
this.iPageCount = ipagecount;
}
//返回內(nèi)部設(shè)置的總頁(yè)數(shù)
public int getPageCount()
{
return this.iPageCount;
}
//內(nèi)部設(shè)置當(dāng)前頁(yè)..
private void setPage(int ipage)
{
this.iPage = ipage;
}
//返回內(nèi)部設(shè)置的總頁(yè)數(shù)
public int getPage()
{
return this.iPage;
}
//顯示翻頁(yè)信息
//參數(shù):總頁(yè)數(shù),總行數(shù),當(dāng)前頁(yè)
//應(yīng)該考慮加一個(gè)查詢參數(shù)列表進(jìn)入本方法--2007-4-12
public String showChangePage()
{
return this.iPage + "/" + this.iPageCount + ">>>";
}
//考慮了翻頁(yè)的選擇查詢
public ResultSet execQuery(String sql,int iPageSize,int iPage)
{//======iRowCount== iPageCount==iPageSize===iPage================
try
{
conn = DriverManager.getConnection(getConnectionUrl(),dbUserName,dbPassword);
stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
rs = stmt.executeQuery(sql);
rs.last();
//獲取總行數(shù) 移動(dòng)到最后,檢索當(dāng)前行編號(hào)。
int iRowCount= rs.getRow();
//計(jì)算總頁(yè)數(shù) 總100行 每頁(yè)10行===〉總頁(yè)數(shù)= 11.4頁(yè)==> 12頁(yè)
int iPageCount = (iRowCount + iPageSize-1) / iPageSize;
if(iPage>iPageCount) iPage = iPageCount;
if(iPage <= 0 ) iPage = 1;
if(iPageCount>0){
//在方法體中已經(jīng)到了指定行
rs.absolute((iPage-1) * iPageSize +1);
}
//自己設(shè)置iPageCount和iRowCount,iPage,避免混淆?!
setPageCount(iPageCount);
setRowCount(iRowCount);
setPage(iPage);
//stmt.close();???
}//end try
catch(SQLException ex)
{
System.err.println("DBConnection.execQuery():" + ex.getMessage());
}//end catch
return rs;
}//end execQuery
//======================================================
//關(guān)閉數(shù)據(jù)庫(kù)
public void closeDB()
{
try
{
//System.out.println("DBConnection.closeDB( here!)" );
if(rs!=null)
{
rs.close();
rs = null;
}
else
{
System.out.println("rs closed!");
}//?????
if(stmt!=null)
{
stmt.close();
stmt = null;
}
else
{
System.out.println("stmt closed!");
}
if(conn!=null)
{
conn.close();
conn = null;
}
else
{
System.out.println("conn closed!");
}
}
catch(Exception ex)
{
//System.err.println("DBConnection.closeDB()" + ex.getMessage());
System.out.println("DBConnection.closeDB()" + ex.getMessage());
}
}
}//end Class
--------------------------------------------------------------------------------------------------------------
二、jsp程序中使用本類過(guò)程
1、<jsp:useBean id="conn" class="newsbean.DBConnection" />
2、處理查詢參數(shù)iPage ,txtSearchKeyword等
3、文章列表:
int iPageSize = 15;//每次讀行數(shù),作為參數(shù)傳入<jsp:setProperty id......沒(méi)用上!
String sql=null;
ResultSet rs =null;
int iRowCount = 0;
int iPageCount = 0;
try{
//===========================
int i = 0;
//l構(gòu)造sql語(yǔ)句。。。
sql="SELECT top 200 number, sms_no, company_card_name, Reg_Date, Dead_Date, OnUse, province, "
+ "City FROM dbo.Company_Card where 1=1 " ;
if(!( txtSearchCompanyCard.equals("")))sql = sql + " and company_card_name like '%" + txtSearchCompanyCard + "%'";
if(!( txtSearchCity.equals("")))sql = sql + " and City ='" + txtSearchCity + "'";
sql = sql + " order by number desc ";
//取得resultset
rs = conn.execQuery(sql,iPageSize,iPage);
//獲取記錄總數(shù)
iRowCount = conn.getRowCount();
//獲取總頁(yè)數(shù)
iPageCount = conn.getPageCount();
//循環(huán)
do{
%>
<tr>
<td>[<%=rs.getRow()%>]</td>
<td><%=rs.getString("sms_no")%></td>
<td><%=rs.getString("company_card_name")%></td>
<td><%=rs.getDate("Reg_Date")%></td>
<td><%=rs.getString("province")%></td>
<td><%=rs.getString("City")%></td>
<td><a href="#" onclick="return domodify('<%=rs.getInt("number")%>')">修改</a></td>
</tr>
<%
}while(++i<iPageSize && rs.next());
}catch(Exception e){
out.print("rs Err:" + e.getMessage());
out.print(sql + "<br/>");
}%>
分享:談CSV文件的生成與分析CSV文件是指Excel可以識(shí)別的后綴名為CSV的文件,網(wǎng)站系統(tǒng)后臺(tái)用來(lái)存儲(chǔ)分析數(shù)據(jù)的時(shí)候有可能會(huì)用到它。其實(shí)CSV文件的讀取和做成比較簡(jiǎn)單,主要的技術(shù)點(diǎn)是文件的讀寫(xiě)。不過(guò)CSV文件的分析和生成有一定的代表性,可以通過(guò)對(duì)CSV文件的生成和分析的實(shí)現(xiàn),來(lái)了解后
- jsp response.sendRedirect不跳轉(zhuǎn)的原因分析及解決
- JSP指令元素(page指令/include指令/taglib指令)復(fù)習(xí)整理
- JSP腳本元素和注釋復(fù)習(xí)總結(jié)示例
- JSP FusionCharts Free顯示圖表 具體實(shí)現(xiàn)
- 網(wǎng)頁(yè)模板:關(guān)于jsp頁(yè)面使用jstl的異常分析
- JSP頁(yè)面中文傳遞參數(shù)使用escape編碼
- 基于jsp:included的使用與jsp:param亂碼的解決方法
- Java Web項(xiàng)目中連接Access數(shù)據(jù)庫(kù)的配置方法
- JDBC連接Access數(shù)據(jù)庫(kù)的幾種方式介紹
- 網(wǎng)站圖片路徑的問(wèn)題:絕對(duì)路徑/虛擬路徑
- (jsp/html)網(wǎng)頁(yè)上嵌入播放器(常用播放器代碼整理)
- jsp下顯示中文文件名及絕對(duì)路徑下的圖片解決方法
JSP教程Rss訂閱編程教程搜索
JSP教程推薦
- JSP由淺入深11—— 標(biāo)記庫(kù)
- 檢測(cè)輸入的字符是否為0-9的數(shù)字(測(cè)試)
- 八種優(yōu)化JSP/Servlet應(yīng)用程序的方法
- jsp的內(nèi)置對(duì)象有什么
- Struts2訪問(wèn)servlet分享
- JSP頁(yè)面中文傳遞參數(shù)使用escape編碼
- JSP頁(yè)面IE無(wú)法打開(kāi)Internet 站點(diǎn)…… 已終止操作 的解決方法
- jsp中實(shí)現(xiàn)上傳圖片即時(shí)顯示效果功能
- JSP調(diào)用SQL server 2000存儲(chǔ)過(guò)程
- Java:Web實(shí)現(xiàn)定時(shí)任務(wù)的簡(jiǎn)便方法
猜你也喜歡看這些
- 為J2EE定制一個(gè)用來(lái)處理錯(cuò)誤的異常處理框架
- JSP頁(yè)面自動(dòng)生成html頁(yè)面或任何格式頁(yè)面
- JSP網(wǎng)站開(kāi)發(fā)環(huán)境的目錄結(jié)構(gòu)標(biāo)準(zhǔn)
- JSP中如何發(fā)送一個(gè)動(dòng)態(tài)圖像
- JSP中可能會(huì)碰到的問(wèn)題解答
- J2ME中實(shí)現(xiàn)可伸展目錄樹(shù)TreeList
- 解答JavaMail的安裝和配置問(wèn)題
- 解決JSP開(kāi)發(fā)Web程序中文顯示的三種方法
- J2ME開(kāi)發(fā)之手機(jī)鍵盤(pán)使用注意問(wèn)題
- 如何解決JSP頁(yè)面顯示亂碼問(wèn)題
- 相關(guān)鏈接:
- 教程說(shuō)明:
JSP教程-jsp分頁(yè)類---統(tǒng)一使用
。