浏览模式: 标准 | 列表分类:系统工程师

用多少查多少,高效jsp分页

Jsp如下:
**********************
<%@ page language="java" import="java.util.*,java.sql.*" %>
<%@ page contentType="text/html;charset=gb2312"%>
<jsp:useBean id="cn" scope="page" class="myConnection.Conn" /><!--引用数据库操作的bean,自己完成,这里不再赘述-->
<%
int curpage=1;//当前页
int page_record=20;//每页显示的记录数
//用下面的方法(sql查询完成,速度快)
curpage=Integer.parseInt(request.getParameter("page"));//获取传递的值,需要显示的页
ResultSet rs=cn.rsexecuteQuery("select top "+page_record+" * from tablename where id not in (select top "+(curpage*page_record)+" id from tablename order by id desc) order by id desc");
//本查询语句得到的是所要显示的1000页的20条记录,大致思路为——子查询排除需要显示的记录前的所有记录,父查询则对余下的记录进行降序排列
while(rs.next) {
  out.println(rs.getInt("id").toString());
}
rs.close();
%>

Tags: jsp分页

快速排序

原数列:28,5,36,3,60,13,55,17,总共8个数据,data[0]到data[7]

get l=data[0]    point to the 28,so  i=0

get r=data[7]=data[n-1]=17 so point to the data[8] so j=17

then start to be  compare the number.

the first one,i=2,data[2]=36 ,j=7,data[7]=17 j=7,i<j,so change the number.

28,5,17,3,60,13,55,36 the l=28 point to the 17,and the r=17,point to the 36.

then the i=4, j=5 i<j,changed the number 

28,5,17,3,13,60,55,36  the l=28 point to the 60  ther=17 ,point to the 13.

then the i=5,j=4,i>j, change the number data[0] and the data[4]

13,5,17,28,60,55,36,and the the queue cut to two parts,

13,5,17,28      60,55,36

then the same method!

Tags: 排序

Lucene demo 调试

运行环境配置:
Jdk1.4 http://java.sun.com/j2ee/
Tomcat5 http://tomcat.apache.org/download-55.cgi
lucene-1.4.3 http://www.apache.org/dyn/closer.cgi/jakarta/lucene/binaries/
假设tomcat安装在C:\tomcat目录,tomcat和java环境配置略过。

  1. 解压lucene1.4.3
  2. 直接把luceneweb.war复制到tomcat的webapps目录,或者把src中的jsp目录复制到tomcat的webapps目录,更改文件夹名为luceneweb,把lucene-demos-1.4.3.jar和lucene-1.4.3.jar两个文件放到luceneweb的WEB-INF\lib目录。
  3. 把解压得到的docs(或者其他的html文档,可以包含子文件夹)放到luceneweb下面(或者其他地方也可以)
  4. 在luceneweb下面建立index文件夹
  5. 运行cmd,输入:
    java -classpath "C:\tomcat\luceneweb\WEB-INF\lib\lucene-1.4.3.jar;C:\tomcat\luceneweb\WEB-INF\lib\lucene-demos-1.4.3.jar" org.apache.lucene.demo.IndexHTML -create -index "C:\tomcat\luceneweb\index" "C:\tomcat\luceneweb\docs"
    最后出现:
    Optimizing index...
    12247 total milliseconds
  6. 修改configuration.jsp,String indexLocation = "/opt/lucene/index";改为String indexLocation = "C:\\tomcat\\luceneweb\\index";
  7. 启动tomcat
  8. 在浏览器中输入http://localhost:8080/luceneweb/,输入lucene查询一下

存储过程分页代码

CREATE PROCEDURE GetRecordFromPage
@tblName varchar(255), -- 表名
@fldName varchar(255), -- 字段名
@PageSize int = 10, -- 页尺寸
@PageIndex int = 1, -- 页码
@IsCount bit = 0, -- 返回记录总数, 非 0 值则返回
@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
@strWhere varchar(1000) = '' -- 查询条件 (注意: 不要加 where)
AS

declare @strSQL varchar(1000) -- 主语句
declare @strTmp varchar(300) -- 临时变量
declare @strOrder varchar(400) -- 排序类型

if @OrderType != 0
begin
set @strTmp = "<(select min"
set @strOrder = " order by [" + @fldName +"] desc"
end
else
begin
set @strTmp = ">(select max"
set @strOrder = " order by [" + @fldName +"] asc"
end

set @strSQL = "select top " + str(@PageSize) + " * from ["
+ @tblName + "] where [" + @fldName + "]" + @strTmp + "(["
+ @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["
+ @fldName + "] from [" + @tblName + "]" + @strOrder + ") as tblTmp)"
+ @strOrder

if @strWhere != ''
set @strSQL = "select top " + str(@PageSize) + " * from ["
+ @tblName + "] where [" + @fldName + "]" + @strTmp + "(["
+ @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["
+ @fldName + "] from [" + @tblName + "] where (" + @strWhere + ") "
+ @strOrder + ") as tblTmp) and (" + @strWhere + ") " + @strOrder

if @PageIndex = 1
begin
set @strTmp = ""
if @strWhere != ''
set @strTmp = " where (" + @strWhere + ")"

set @strSQL = "select top " + str(@PageSize) + " * from ["
+ @tblName + "]" + @strTmp + " " + @strOrder
end

if @IsCount != 0
set @strSQL = "select count(*) as Total from [" + @tblName + "]"

exec (@strSQL)
GO

/*分页存储过程
Descript:分页存储过程
Author:Blue.Dream
Date:2004-8-18 21:01
*/
Create PROCEDURE ListPage(
@tblName nvarchar(200), ----要显示的表或多个表的连接
@fldName nvarchar(200) = '*', ----要显示的字段列表
@pageSize int = 10, ----每页显示的记录个数
@page int = 1, ----要显示那一页的记录
@pageCount int = 1 output, ----查询结果分页后的总页数
@Counts int = 1 output, ----查询到的记录数
@fldSort nvarchar(100) = null, ----排序字段列表或条件
@Sort bit = 0, ----排序方法,0为升序,1为降序
@strCondition nvarchar(200) = null, ----查询条件,不需where
@ID nvarchar(50) ----主表的主键
)
AS
SET NOCOUNT ON
Declare @sqlTmp nvarchar(1000) ----存放动态生成的SQL语句
Declare @strTmp nvarchar(1000) ----存放取得查询结果总数的查询语句
Declare @strID nvarchar(1000) ----存放取得查询开头或结尾ID的查询语句
Declare @sqlSort nvarchar(200) ----存放临时生成的排序条件
Declare @intCounts int ----要移动的记录数
Declare @BeginID int ----开始的ID
Declare @EndID int ----结束的ID



--------首先生成排序方法---------
if @Sort=0 --升序
begin
if not(@fldSort is null)
set @sqlSort = ' Order by ' + @fldSort
else
set @sqlSort = ' Order by ' + @ID
end
else --降序
begin
if not(@fldSort is null)
set @sqlSort = ' Order by ' + @fldSort + ' DESC'
else
set @sqlSort = ' Order by ' + @ID + ' DESC '
end


--------生成查询语句--------
--此处@strTmp为取得查询结果数量的语句
if @strCondition is null --没有设置显示条件
begin
set @sqlTmp = @fldName + ' From ' + @tblName
set @strTmp = 'select @Counts=Count(' + @ID + ') FROM '+@tblName
set @strID = ' From ' + @tblName
end
else
begin
set @sqlTmp = + @fldName + 'From ' + @tblName + ' where ' + @strCondition
set @strTmp = 'select @Counts=Count(' + @ID + ') FROM '+@tblName + ' where ' + @strCondition
set @strID = ' From ' + @tblName + ' where ' + @strCondition
end



----取得查询结果总数量-----
exec sp_executesql @strTmp,N'@Counts int out ',@Counts out

--取得分页总数
if @Counts <= @pageSize
set @pageCount = 1
else
set @pageCount = (@Counts / @pageSize) + 1


--计算要移动的记录数
if @page = 1
set @intCounts = @pageSize
else
begin
set @intCounts = (@page-1) * @pageSize + 1
end

-----取得分页后此页的第一条记录的ID
set @strID = 'select @BeginID=' + @ID + ' ' + @strID



set @intCounts = @intCounts - @pageSize + 1
set rowcount @intCounts
exec sp_executesql @strID,N'@BeginID int out ',@BeginID out

-----取得分页后此页的最后一条记录的ID
set @intCounts = @intCounts + @pageSize - 1
print @intCounts
set rowcount @intCounts
exec sp_executesql @strID,N'@BeginID int out ',@EndID out


------恢复系统设置-----
set rowcount 0
SET NOCOUNT OFF

------返回查询结果-----
if @strCondition is null
set @strTmp = 'select ' + @sqlTmp + ' where ' + @ID + ' between ' + str(@BeginID) + ' and ' + str(@EndID)
else
set @strTmp = 'select ' + @sqlTmp + ' where ' + @ID +' (between ' + str(@BeginID) + ' and ' + str(@EndID) + ') and ' + @strCondition

if not(@sqlSort is null)
set @strTmp = @strTmp + @sqlSort
exec sp_executesql @strTmp

GO

半天的xml的学习

由于在毕设中,我负责rss,和tag的这一块。

所以今天下载了本xml的基础看看,以前都是了解些自己需要用的。

没有作过多的学习,嘿嘿,今天从什么是xml开始学。

在开发中,xml是一个涉及面很广的东西。

用eclipse的时候,一般的配置文件都是xml的格式。

hibernate的映射文件也是xml的数据格式。还有一些标签的文件也是。

用ms.net的时候,里面的除了一些工程文件和项目的文件,其他的基本都是以

<?xml ?>开始的,xml这么重要,大项目都在用。

今天实现了把xml绑定到html的table中,因为要用到xpath,所以还是有一点难度的。

如果html的设计很好的话,速度应该很快。

如果用一个文件夹来做xml的存放目录,作为数据库来是用。

动态添加的时候,自动生成一个xml文件,来指定数据库的xml文档id。

显示的时候动态的调用,那么,页面的执行速率应该比那些依据传统的软件工程的模式制作的软件工程要速度快很多。

根据在casio实习的经验,如果用xml控制输出样式的话,那么一个页面的读取分为三步

1)载入页面的xml样式

2)载入页面所需调用的xml数据库

2)显示给用户

那么,这样一来,在页面的显示速度会比传统的速度快很多。

拿我们现在用的这个模式来说

1)接受客户请求,映射所需地址,叶面可以用javascript来调用相关的xml的xpath等属性。

2)控制层给一个命令

3)hibernate连接数据库,并返回所需数据

4)载入struts的标签

5)前台显示

那么,用xml是不是快很多了,如果在数据库映射中,不用hibernate,直接用数据库生成相应的xml文件,显示的时候调用。

那么,叶面的访问速度应该快很多。

但是如果数据量大就不知道如何处理了,服务器毕竟有限嘛 。

Tags: xml javascript