在jsp页面点击某一列,对表进行正序排序,再点击实现倒序排序-与分页不能共同实现
在jsp页面点击某一列,对表进行正序排序,再点击实现倒序排序-与分页不能共同实现
通过sql order by 排序的列 后分页显示的数据发生变化,
因为是全部数据排序后再分页,能不能只把全部数据中只排序当前页的数据,这样分页后正常。
sql要怎么写?????
-------------------------------------------------
if(request.getParameter("sort1")!=null){
sql.append("order by "+request.getParameter("sort1")+" "+request.getParameter("sort2"));
}
CachedRowSet rs=DBManager.getDBManagerInstance().exeSearchSql(sql.toString());
rs.last();
intRowCount=rs.getRow();
intPageCount=(intRowCount+intPageSize-1)/intPageSize;
if(intPage >intPageCount) intPage=intPageCount;
<%if(intPageCount >0)
{rs.absolute((intPage-1)*intPageSize+1);
i=1;while(i <=intPageSize&&!rs.isAfterLast())
{% >
<%rs.next();i++; }} % >
<%
if(intPage!=1){% >
<a href="my_account_pic.jsp?page=1" >First </a > ¦
<a href="my_account_pic.jsp?page= <%=intPage-1% >" >Previous </a > ¦
<%} if(intPage!=intPageCount) {% >
<a href="my_account_pic.jsp?page= <%=intPage+1% >" >Next </a > ¦
<a href="my_account_pic.jsp?page= <%=intPageCount% >" >Last </a > ¦
<%}% >
[解决办法]
点击排序的时候重新调用方法查询:
public List search(String fy_sql)
{
String sql = select t.* from ( fy_sql ) t order by name;
//调用查询方法
...
return list;//返回结果集(这里自己设定^_^)
}
以查询出来的数据再次作为一个表进行排序查询!
[解决办法]
两个按钮,加两个Action方法 ,一个方法查询数据库 ,查询加条件order by XXX DESC,另一个ORDER BY XXX ASC
[解决办法]
select * from table where id >=3 and id <=7 order by name asc
select * from table where id >=3 and id <=7 order by name desc
就是这两句的切换就是了,定义个变量,等于0时,点的时候判断变量,等于0执行第一句,此时给一个变量设置成1,等于1执行第二句,变量变为0
[解决办法]
建议你用脚本实现啊
[解决办法]
个人觉得对页面上的表格数据进行某列的排序最好在客户端通过js实现,这样就能分页分离开来。
因为客户端通过js进行排序只是针对当前页面显示的数据进行排序,并不会涉及到服务端的数据,因此也就不会打乱服务端所有数据库的顺序,也就不会产生和分页的矛盾。
否则和分页的矛盾是不好处理的
[解决办法]
mark
[解决办法]
用JS实现啦,不需要再去查数据啊.你只排序当前显示的啊,用JS把Table里的行换一个,这想这个实现应该不难吧.定位到<td>然后根据<TD>里的值进行换行.建议百度一下"table 行排序",然后排序的算法就要看你自己的能力了