日期:2014-05-16 浏览次数:20406 次
?
/**************************************************************/
作者:wallimn(网名:wallimn、邮件:wallimn@sohu.com
)
博客:http://blog.csdn.net/wallimn?http://wallimn.iteye.com
时间:2007-09-10(2008-10-04修改)
声明:此文欢迎转载,转载请保留本人信息。呵呵。更多文章,请访问我的博客。
/**************************************************************/
?
以前用ORACLE时,分页使用ROWNUM做条件就可以了,不管效率如何,反正实现起来比较容易。
那么ACCESS如何实现分页功能呢?看了些资料说得有些复杂,要写好些代码,我想到一个好方法,来跟大家分享,也就是一个SQL语句:
?select top 15 * from YOURTABLE where ID not in(select top 15 ID from YOURTABLE order by ID desc)? order by ID desc
?稍解释一下,15呢是每页的行数,YOURTABLE是表名,ID是表中主键字段(当然你也可以用别的),我上面的SQL语句,是取出第二页(第二个15条)记录。想变页码,只要把后面的15变成相应的倍数就可以了。
用这种方式,结合不带分页功能的DataRepeater插件,我三下五除二就写好的记事本程序。不要笑话我,我的.NET的新手,先写这个练练手。
如果有人感兴趣,请留言,我可以把代码贴出来。
?
请注意:
如果取第一个15条记录,SQL语句不能这样写:
select top 15? * ?from YOURTABLE where ID not in(select top?0 ID from YOURTABLE order by ID desc)? order by ID desc
这样写会报错。直接写成:
select top 15 ?* ?from YOURTABLE?? order by ID desc
?
如果要加限制条件,可以这样写:
select top 15? *? from YOURTABLE where ID not in(select top?15 ID from YOURTABLE where??NAME='wallimn'?order by ID desc) and?NAME='wallimn'? order by ID desc
?
/**************************************************************/
作者:王力猛(网名:wallimn、邮件:wallimn@sohu.com
)
博客:http://blog.csdn.net/wallimn
时间:2007-09-10(2008-10-04修改)
声明:此文欢迎转载,转载请保留本人信息。呵呵。更多文章,请访问我的博客。
/**************************************************************/
?