当前位置:首页 » 编程语言 » 分页sql语句

分页sql语句

发布时间: 2022-01-14 19:04:19

⑴ 求一条sql分页语句。

--sql server可以创建一个存储过程来实现:
create proc AAA @a int,@b int
as
select top @a *
from (select top @b * from table_1 order by id asc) table_2
order by id desc

--执行存储过程
exec AAA '@a','@b'

⑵ 在oracle数据库中的分页SQL语句怎么写

前提:

分页参数:size = 20 page = 2;

没有order by的查询;

嵌套子查询,两次筛选(推荐使用)。

SQL语句:

SELECT *

FROM (SELECT ROWNUM AS rowno, t.*

FROM DONORINFO t

WHERE t.BIRTHDAY BETWEEN TO_DATE ('19800101', 'yyyymmdd')

AND TO_DATE ('20060731', 'yyyymmdd')

AND ROWNUM <= 20*2) table_alias

WHERE table_alias.rowno > 20*(2-1);

(2)分页sql语句扩展阅读:

rownum总是从1开始的,第一条不满足去掉的话,第二条的rownum 又成了1。依此类推,所以永远没有不满足条件的记录。

可以这样理解:rownum是一个序列,是Oracle数据库从数据文件或缓冲区中读取数据的顺序。它取得第一条记录则rownum值为1,第二条为2。

依次类推:当使用“>、>=、=、between...and”这些条件时,从缓冲区或数据文件中得到的第一条记录的rownum为1,不符合sql语句的条件,会被删除,接着取下条。下条的rownum还会是1,又被删除,依次类推,便没有了数据。

⑶ 一个分页的SQL语句问题

假设:
pagecount=30 --每页显示的记录数

Currentpage=3 --当前页码

select top 30 ID,Title from books
where Publisheris =(....)
and id not in (select top 30*(3-1) id from books where Publisherid =(...) order by id)
order by id

(...) 跟你那个一样,就不写了,两处都是一样的

你的错误是在id not in中没有加那个(...)的条件

⑷ 如何使用sql语句进行分页操作

sql语句是不能进行分页操作的,它只查出一个相应条件的数据记录集。而分页操作,是由程序员用相应的软件开发语言设计算法,而过进行分页操作。谢谢

⑸ 关于分页查询的sql语句

这里的K不仅仅是个别名的作用,他把 (select *,row_number() over(order BY UserID) rowIndex from userinfo)做为一个表来查询 ,如果不加则作为一个查询结果集,SQL无法再查询结果集上在进行查询

⑹ SQL Server 分页 查询语句

四种方式实现SQLServer 分页查询
SQLServer 的数据分页:
假设现在有这样的一张表:
CREATE TABLE test
(
id int primary key not null identity,
names varchar(20)
)
然后向里面插入大约1000条数据,进行分页测试
假设页数是10,现在要拿出第5页的内容,查询语句如下:
--10代表分页的大小
select top 10 *
from test
where id not in
(
--40是这么计算出来的:10*(5-1)
select top 40 id from test order by id
)
order by id
原理:需要拿出数据库的第5页,就是40-50条记录。首先拿出数据库中的前40条记录的id值,然后再拿出剩余部分的前10条元素

第二种方法:
还是以上面的结果为例,采用另外的一种方法
--数据的意思和上面提及的一样
select top 10 *
from test
where id >
(
select isnull(max(id),0)
from
(
select top 40 id from test order by id
) A
)
order by id
原理:先查询前40条记录,然后获得其最id值,如果id值为null的,那么就返回0
然后查询id值大于前40条记录的最大id值的记录。
这个查询有一个条件,就是id必须是int类型的。

第三种方法:
select top 10 *
from
(
select row_number() over(order by id) as rownumber,* from test
) A
where rownumber > 40
原理:先把表中的所有数据都按照一个rowNumber进行排序,然后查询rownuber大于40的前十条记录
这种方法和oracle中的一种分页方式类似,不过只支持2005版本以上的
第四种:
存储过程查询
创建存储过程
alter procere pageDemo
@pageSize int,
@page int
AS
declare @temp int
set @temp=@pageSize*(@page - 1)
begin
select top (select @pageSize) * from test where id not in (select top (select @temp) id from test) order by id
end
执行存储过程
exec 10,5

⑺ sql语句查询并且加分页

你的意思是前五行是固定的,后十行进行分页是么,前五行固定写死,后十行用参数或动态sql来进行分页。例如第一页:
select top 5 id,readcount,weight from table1 order by readcount desc
union all
select top 10,id,readcount,weight from table1 order by weight desc --这句进行动态sql或传参数进行分页,网上分页的sql很多。有问题再追问。

⑻ SQl分页语句

DECLARE @pagesize INT --每页记录条数
declare @pageindex INT --页索引
SET @pagesize=5
SET @pageindex=3

DECLARE @sql VARCHAR(800) --拼接主查询语句 top法
set @sql='SELECT TOP '+Cast(@pagesize AS varchar)+'*
FROM #table WHERE id NOT IN
(SELECT TOP '+CAST(((@pageindex-1)*@pagesize) AS VARCHAR) +' id FROM #table)'
PRINT @sql
EXEC (@sql)

⑼ 如何用sql语句 实现分页查询

适用于 SQL Server 2000/2005

SELECT TOP 页大小 *

FROM table1

WHERE id NOT IN

SELECT TOP 页大小*(页数-1) id FROM table1 ORDER BY id

⑽ 求SQL分页的语句

2个参数Start end
start 开始 end 结束
例如第二页从Start11条开始 结束end 21百

select * from (select rownum a,NEWS.* from NEWS where rownum<='"+end+"') b where b.a>'"+start+"'"

方法2 select * from NEWS limit a,b
a就是从第几条开始 b就是查询出的条数
例如 从第10条开始后的10条select * from NEWS limit 10,10
从第6条开始后的8条select * from NEWS limit 6,8

热点内容
iqoo安卓11变声器在哪里 发布:2024-12-22 15:46:45 浏览:251
ie锁定初始密码在哪里找 发布:2024-12-22 15:44:48 浏览:295
linuxtcp窗口 发布:2024-12-22 15:34:24 浏览:947
安卓官翻机和原装有什么区别 发布:2024-12-22 15:34:24 浏览:661
linux挂载的磁盘 发布:2024-12-22 15:34:23 浏览:233
密码不允许含有字符是什么意思 发布:2024-12-22 15:30:15 浏览:168
图片压缩求 发布:2024-12-22 15:05:28 浏览:780
我的世界tis服务器怎么加 发布:2024-12-22 14:48:09 浏览:579
方舟服务器虚拟内存是什么意思 发布:2024-12-22 14:21:52 浏览:956
磁力片编程课 发布:2024-12-22 14:10:57 浏览:272