当前位置:  数据库>sqlserver

分页存储过程(三)在sqlserver中打造更加准确的分页结果

    来源: 互联网  发布时间:2014-09-05

    本文导语:  有人提出游标不好,会锁定行,幸亏我锁定的是临时表,不是数据表,不影响数据表的写操作。 下面是14楼的回复,让我茅塞顿开,于是有了今天的改进版,取消了游标的使用,临时表还是存在的,谢谢。 其实你只要分成两...

有人提出游标不好,会锁定行,幸亏我锁定的是临时表,不是数据表,不影响数据表的写操作。

下面是14楼的回复,让我茅塞顿开,于是有了今天的改进版,取消了游标的使用,临时表还是存在的,谢谢。

其实你只要分成两次查询即可:
1, 还是用Row_Number查主表分页
2, Row_Number查主表分页 inner join 明细表..用不到游标的.

代码如下:

--不用游标的分页
--先将分页的主表放在临时表中,然后用临时表和子表联合查询,来获取子表信息
--既保证了分页的正确性,也包括了子表信息
CREATE TABLE #order
(
number BIGINT,
orderseqno VARCHAR(36),
)
insert into #order
SELECT * FROM (SELECT ROW_NUMBER() OVER (ORDER BY oi.CreateDate DESC) AS rownumber,oi.OrderSeqNO
FROM OrderInfo oi WHERE oi.OrderSeqNO LIKE '%2%' ) AS o
WHERE o.rownumber BETWEEN 10 AND 20

SELECT * FROM #order INNER JOIN OrderDetail od ON od.OrderSeqNO=#order.orderseqno

DROP TABLE #order


代码如下:

--SELECT TOP 10 oi.OrderSeqNO, oi.GoodsName ,ci.CompanyName,od.*
--FROM OrderInfo oi INNER JOIN CompanyInfo ci ON oi.CompanyID=ci.CompanyID
--LEFT JOIN OrderDetail od ON oi.OrderSeqNO=od.OrderSeqNO


--使用row_unmber()实现分页
--本来我们想要的结果是10条订单,结果却不是10条订单,而是10条明细
--其实是针对的子表进行分页了,订单并不是要显示的个数,出来的个数是明细的个数
--就是因为主表和子表联合查询的结果,主表记录和子表记录是1:N的关系,一个主表记录有多个明细

--建立聚集索引
-- CLUSTERED INDEX INDEX_OrderInfo ON OrderInfo (OrderSeqNo)
--显示查询执行计划
--SET STATISTICS IO ON

select * from
(SELECT ROW_NUMBER () OVER (ORDER BY oi.createdate DESC) AS rownumber,oi.orderseqno ,od.OrderDetailID
FROM OrderInfo oi LEFT JOIN OrderDetail od ON oi.OrderSeqNO=od.OrderSeqNO
WHERE oi.OrderSeqNO LIKE '%2%'
) AS o
WHERE rownumber BETWEEN 10 AND 20

--不用游标的分页
--先将分页的主表放在临时表中,然后用临时表和子表联合查询,来获取子表信息
--既保证了分页的正确性,也包括了子表信息
CREATE TABLE #order
(
number BIGINT,
orderseqno VARCHAR(36),
)
insert into #order
SELECT * FROM (SELECT ROW_NUMBER() OVER (ORDER BY oi.CreateDate DESC) AS rownumber,oi.OrderSeqNO
FROM OrderInfo oi WHERE oi.OrderSeqNO LIKE '%2%' ) AS o
WHERE o.rownumber BETWEEN 10 AND 20

SELECT * FROM #order INNER JOIN OrderDetail od ON od.OrderSeqNO=#order.orderseqno

DROP TABLE #order
--解决上面的问题,有以下几种办法
--1、先根据条件查询主表记录,然后在C#代码中循环,再次到数据库查询每条主表记录的明细信息,然后赋值给属性
--2、在数据库的存储过程中使用游标,也是先查询主表记录,然后使用游标循环的过程中,查询子表信息,然后在C#中
--集中处理
--很显然,后一种减少了数据库的往来开销,一次获取了想要的数据,个人认为要比第一种好,欢迎大家一起讨论更好的办法

--需要注意的就是ROW_NUMBER()返回的类型是bigint,而不是int
--下面是游标的存储过程


--建立主表临时表
CREATE TABLE #temp
(
rownumber bigint,
orderseqno VARCHAR(36),
goodsname VARCHAR(50),
companyname VARCHAR(100)
)
--建立子表临时表
CREATE TABLE #detail
(
orderseqno VARCHAR(36),
detailid UNIQUEIDENTIFIER,
unitprice DECIMAL(12,2),
Qty int
)
--插入主表数据到主表临时表

insert into #temp
SELECT *
--oo.rownumber, oo.OrderSeqNO, oo.GoodsName, oo.CompanyName
FROM
(SELECT ROW_NUMBER () OVER (ORDER BY oi.createdate DESC) AS rownumber,
oi.OrderSeqNO, oi.GoodsName ,ci.CompanyName
FROM OrderInfo oi INNER JOIN CompanyInfo ci ON oi.CompanyID=ci.CompanyID
WHERE oi.CreateDate

    
 
 

您可能感兴趣的文章:

  • 各位大虾,谁知道怎么通过jdbc调用sqlserver2000的存储过程
  • sqlserver 批量删除存储过程和批量修改存储过程的语句
  • sqlserver中查找所有包含了某个文本的存储过程
  • sqlserver 存储过程中If Else的用法实例
  • sqlserver 复制表 复制数据库存储过程的方法
  • SQLServer用存储过程实现插入更新数据示例
  • 一次性压缩Sqlserver2005中所有库日志的存储过程
  • sqlserver 通用分页存储过程
  • C#操作图片读取和存储SQLserver实现代码
  • 查询Sqlserver数据库死锁的一个存储过程分享
  • Sqlserver 存储过程中结合事务的代码
  • sqlserver 系统存储过程 中文说明
  • 使用sqlserver存储过程sp_send_dbmail发送邮件配置方法(图文)
  • sqlserver数据库使用存储过程和dbmail实现定时发送邮件
  • 做购物车系统时利用到得几个sqlserver 存储过程
  • SQLSERVER Pager store procedure分页存储过程
  • sqlserver 存储过程动态参数调用实现代码
  • sqlserver 千万数量级分页存储过程代码
  • 分页存储过程(二)在sqlserver中返回更加准确的分页结果
  • sqlserver关于分页存储过程的优化【让数据库按我们的意思执行查询计划】
  • mysql 存储过程实例和基本语法
  • 在SQL Server中使用SQL语句查询一个存储过程被其它所有的存储过程引用的存储过程名
  • java调用sql server存储过程,如何取存储过程返回码(不是结果集)
  • MYSQL存储过程里代返回值的存储过程怎么写
  • 用proceduredataset孔件来调用存储过程时,要用到其属性procedure.我自己写好的存储过程如何放在里面?
  • 请问各位大侠怎样在java中调用存储过程和接受存储过程的返回参数
  • 分享:在存储过程中使用另一个存储过程返回的查询结果集的方法
  • 分页存储过程(用存储过程实现数据库的分页代码)
  • Mysql存储过程学习笔记--建立简单的存储过程
  • oracle分页存储过程 oracle存储过程实例
  • oracle 在一个存储过程中调用另一个返回游标的存储过程
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • java将类序列化并存储到mysql(使用hibernate)
  • 用C或C++编程,模拟可变分区存储管理且首次适应的算法实现存储器的分配与回收
  • 服务器存储快照和数据库快照详解
  • 数据库存储, 改用TXT文件存储
  • Docker容器与企业存储的结合思考
  • 这句话什么意思:“分页存储管理是一个单一的线性地址空间,分段存储管理的作业地址空间是二维的。”?
  • 急求 unix 与linux在文件存储上 和数据存储上有哪些不同 希望各路英雄帮忙
  • 请教:如何选购NAS网络存储器?做视频服务器的存储用。急!!!
  • 数据库存储还是直接存储在硬盘上好?(来者有分)
  • 急!50分!我现在想要在VECTOR中直接存储结果集???但不想使用"在VECTOR中存储一个
  • 分布式存储系统 dCache DSS
  • 关于操作系统中虚拟存储技术的问题
  • 电子邮件存储系统 ElasticInbox
  • 对象存储系统 Manta
  • 集群文件存储系统 Hados
  • 随机存储数据库 Aerospike
  • 开源存储管理平台 Openfiler 中文版
  • 请教关于存储系统的整体方案
  • 云存储管理工具 Cloudloop
  • 数据流的存储方案
  • 分布式存储管理系统 Sheepdog




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3