前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >分页的sql语句_自动分页

分页的sql语句_自动分页

作者头像
全栈程序员站长
发布2022-09-27 10:58:01
1.5K0
发布2022-09-27 10:58:01
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

下文将为您介绍三种SQL分页语句写法,如果您也遇到过类似的问题,不妨一看,相信对您会有所启迪。

SQL分页操作是经常会遇到的,下面就将为您介绍三种SQL分页语句,供您参考,希望对您学习SQL分页能够有所帮助。

方法一(适用于 SQL Server 2000/2005)

SELECT TOP 页大小 * FROM table1 WHERE id NOT IN ( SELECT TOP 页大小*(页数-1) id FROM table1 ORDER BY id ) ORDER BY id 方法二(适用于 SQL Server 2000/2005)

SELECT TOP 页大小 * FROM table1 WHERE id > ( SELECT ISNULL(MAX(id),0) FROM ( SELECT TOP 页大小*(页数-1) id FROM table1 ORDER BY id ) A ) ORDER BY id 方法三(适用于 SQL Server 2005)

SELECT TOP 页大小 * FROM ( SELECT ROW_NUMBER() OVER (ORDER BY id) AS RowNumber,* FROM table1 ) A

WHERE RowNumber > 页大小*(页数-1)

———————————————————-

/// <summary> /// 将原始SQL语句改造成支持分页的SQL语句 /// </summary> /// <param name=”sql”>原始sql语句</param> /// <param name=”page”>第几页</param> /// <param name=”pageSize”>每页多少记录</param> /// <param name=”primaryField”>原始sql语句主键字段</param> /// <returns></returns> string GetPageSql(string sql, int page, int pageSize,string primaryField) { StringBuilder pageSQL = new StringBuilder(); pageSQL.Append(string.Format (“SELECT TOP {0} * From “,pageSize )); pageSQL.Append(” ( “); pageSQL.Append(string.Format (” SELECT ROW_NUMBER() OVER (ORDER BY {0}) AS RowNumber,* FROM “,primaryField )); pageSQL.Append(string.Format(“({0}) tempTable1”, sql)); pageSQL.Append(” ) tempTable2 “); pageSQL.Append(string.Format(” WHERE RowNumber > {0}*({1}-1) “,pageSize , page)); return pageSQL.ToString(); }

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/179166.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档