sql2008 数据库分页语句

sql 复制代码
CREATE PROCEDURE Proc_GetBillPage
    @PageIndex INT,
    @PageSize INT
AS
BEGIN
    SET NOCOUNT ON;
    
    SELECT 
        Id, 账单号, 金额, 交易时间, TotalCount
    FROM (
        SELECT 
            ROW_NUMBER() OVER(ORDER BY Id DESC) AS RowNum,
            COUNT(*) OVER() AS TotalCount,
            Id, 账单号, 金额, 交易时间
        FROM 账单表
        WHERE 状态 = '有效'
    ) AS TempTable
    WHERE RowNum BETWEEN (@PageIndex - 1) * @PageSize + 1 AND @PageIndex * @PageSize;
END;
GO

-- 调用存储过程
EXEC Proc_GetBillPage @PageIndex = 2, @PageSize = 10;

带总条数的分页(前端分页需总页数)

实际开发中通常需要返回「当前页数据 + 总条数」,可通过 COUNT(*) OVER() 实现(无需额外查询):

sql 复制代码
DECLARE @PageIndex INT = 2;
DECLARE @PageSize INT = 10;

SELECT 
    -- 分页数据
    Id, 账单号, 金额, 交易时间,
    -- 总条数(所有符合条件的记录数,整页数据中该值相同)
    TotalCount
FROM (
    SELECT 
        ROW_NUMBER() OVER(ORDER BY Id DESC) AS RowNum,
        COUNT(*) OVER() AS TotalCount, -- 计算总条数
        t.Id, t.账单号, t.金额, t.交易时间
    FROM 账单表 t
    WHERE t.交易时间 >= '2026-01-01'
) AS TempTable
WHERE TempTable.RowNum BETWEEN (@PageIndex - 1) * @PageSize + 1 AND @PageIndex * @PageSize;
相关推荐
SuniaWang7 小时前
《Agentx专栏》03-架构设计:AgentX的六层架构是如何生长出来的
java·数据库·redis·docker·ai·架构
键盘上的猫头鹰7 小时前
【从零学MySQL(二)】数据库基础操作、数据类型与约束(附Navicat演示)
数据库·mysql·数据分析·数据可视化
东风破1377 小时前
达梦DEM和DFM的介绍、搭建学习记录
数据库·学习·dm达梦数据库
小江的记录本7 小时前
【Kafka核心】Kafka 3.0+ KRaft模式(替代ZooKeeper)核心原理与优势
java·数据库·分布式·后端·zookeeper·kafka·rabbitmq
treacle田7 小时前
达梦数据库-数据库主备集群更改实例目录及相关目录步骤-记录总结
数据库·达梦数据库主备集群更改实例目录
会编程的土豆8 小时前
GORM 标签详解(数据库字段映射核心)
数据库·gorm
KaMeidebaby8 小时前
卡梅德生物技术快报|真核蛋白表达信号肽筛选实验全流程复盘
服务器·前端·数据库·人工智能·算法
malog_8 小时前
Milvus向量数据库:AI时代的搜索革命
数据库·人工智能·后端·milvus
胡耀超9 小时前
《设计数据密集型应用》(DDIA, 2nd ed.) 心智模型导览——《Designing Data-Intensive Applications》书介绍导航
大数据·数据库·分布式·ai·架构·数据
ai安歌9 小时前
鸿蒙PC:Qt适配OpenHarmony实战【人名录】:单机联系人卡片,不读系统通讯录也能演示详情联动
数据库·qt·harmonyos