ObjectDataSource控件实现分页功能

hnsdwhl 2009-04-05 11:35:06
在看书时,书上说要使ObjectDataSource控件实现分页功能,需要创建如下存储过程,对于下面这个存储过程看得不是太懂,请高手指点一下。
CREATE PROCEDURE dbo.GetPagedMovies
(
@StartRowIndex INT,
@MaximumRows INT
)
AS

-- Create a temp table to store the select results
CREATE TABLE #PageIndex
(
IndexId INT IDENTITY (1, 1) NOT NULL,
RecordId INT
)

-- INSERT into the temp table
INSERT INTO #PageIndex (RecordId)--这里怎么将定义的字段插入表中啊,不太明白
SELECT Id FROM Movies--这条语句有何作用

-- Get a page of movies
SELECT
Id,
Title,
Director,
DateReleased
FROM
Movies
INNER JOIN #PageIndex WITH (nolock)
ON Movies.Id = #PageIndex.RecordId--这条语句作何分析
WHERE
#PageIndex.IndexID > @startRowIndex
AND #PageIndex.IndexID < (@startRowIndex + @maximumRows + 1)--这里又是什么意思
ORDER BY
#PageIndex.IndexID

小弟只会创建一些简单的存储过程,对于这么复杂的存储过程,还是第一次看到,呵呵。
...全文
64 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
ojekleen 2009-04-05
  • 打赏
  • 举报
回复
INNER JOIN #PageIndex WITH (nolock)
ON Movies.Id = #PageIndex.RecordId--这条语句作何分析
inner join on ...多表关系查询,

#PageIndex.IndexID > @startRowIndex
AND #PageIndex.IndexID < (@startRowIndex + @maximumRows + 1)--这里又是什么意思

即创建的#pageindex表的自增列大于开始行数和小于开始行数+每页行数,这即查询第几页数据的意思
ojekleen 2009-04-05
  • 打赏
  • 举报
回复
-- INSERT into the temp table
INSERT INTO #PageIndex (RecordId)--这里怎么将定义的字段插入表中啊,不太明白
SELECT Id FROM Movies--这条语句有何作用

你百度一下insert into select
这句意思是把表Movies的ID全部插入表#PageIndex的RecordId字段中..
hnsdwhl 2009-04-05
  • 打赏
  • 举报
回复
经过高手的一番分析,使我豁然开朗,谢谢!

62,268

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧