最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

二种MSSQL分页存储过程实例应用

来源:动视网 责编:小采 时间:2020-11-09 10:02:59
文档

二种MSSQL分页存储过程实例应用

二种MSSQL分页存储过程实例应用:二种MSSQL分页存储过程实例应用 二种MSSQL分页存储过程实例应用 MSSQL分页在小型数据网站应用中,不需要用到存存储过程,只有上万百,千万级时就会用到存储过程, 创建存储过程 CREATE PROCEDURE pagination @tblName varchar
推荐度:
导读二种MSSQL分页存储过程实例应用:二种MSSQL分页存储过程实例应用 二种MSSQL分页存储过程实例应用 MSSQL分页在小型数据网站应用中,不需要用到存存储过程,只有上万百,千万级时就会用到存储过程, 创建存储过程 CREATE PROCEDURE pagination @tblName varchar


二种MSSQL分页存储过程实例应用



二种MSSQL分页存储过程实例应用

MSSQL分页在小型数据网站应用中,不需要用到存存储过程,只有上万百,千万级时就会用到存储过程,

创建存储过程
CREATE PROCEDURE pagination
@tblName varchar(255), -- 表名
@strGetFields varchar(1000) = '*', -- 需要返回的列
@fldName varchar(255)='', -- 排序的字段名(可包含如TABLE.FLDNAME形式)
@PageSize int = 10, -- 页尺寸
@PageIndex int = 1, -- 页码
@doCount bit = 0, -- 返回记录总数, 非 0 值则返回
@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序
@strWhere varchar(1500) = '' -- 查询条件 (注意: 不要加 where)
AS
declare @strSQL varchar(5000) -- 主语句
declare @strTmp varchar(110) -- 临时变量
declare @strOrder varchar(400) -- 排序类型
declare @fldName_t varchar(255) -- 在分页时用的排序字段名,不包含多表并列时的表名
set @fldName_t = right(@fldName,len(@fldName)-CHARINDEX('.',@fldName))
if @doCount != 0
begin
if @strWhere !=''
set @strSQL = 'select count(*) as Total from ' + @tblName + ' where
else
set @strSQL = 'select count(*) as Total from ' + @tblName + ''
end
--以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都是@doCount为0的情况
else
begin
if @OrderType != 0
begin
set @strTmp = '<(select min'
set @strOrder = ' order by ' + @fldName +' desc'
--如果@OrderType不是0,就执行降序,这句很重要!
end
else
begin
set @strTmp = '>(select max'
set @strOrder = ' order by ' + @fldName +' asc'
end
if @PageIndex = 1
begin
if @strWhere != ''
set @strSQL = 'select top ' + str(@PageSize) +' + ' from ' + @tblName + ' where ' + @strWhere + ' ' + @strOrder
else
set @strSQL = 'select top ' + str(@PageSize) +' + ' from '+ @tblName + ' '+ @strOrder
--如果是第一页就执行以上代码,这样会加快执行速度
end
else
begin
--以下代码赋予了@strSQL以真正执行的SQL代码
set @strSQL = 'select top ' + str(@PageSize) +' + ' from '+ @tblName + ' where ' + @fldName + ' ' + @strTmp + ' ('+ @fldName_t + ') from (select top ' + str((@PageIndex-1)*@PageSize) + ' '+ @fldName + ' from ' + @tblName + '' + @strOrder + ') as tblTmp)'+ @strOrder
if @strWhere != ''
set @strSQL = 'select top ' + str(@PageSize) +' + ' from '+ @tblName + ' where ' + @fldName + ' ' + @strTmp + ' ('+ @fldName_t + ') from (select top ' + str((@PageIndex-1)*@PageSize) + ' '+ @fldName + ' from ' + @tblName + ' where ' + @strWhere + ' '+ @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder
end
end
exec (@strSQL)
go

--测试
create table news --建表
(
n_id int iDENTITY(1,1) primary key,
n_title char(200),
n_content text
)

--写循环插入1000000条的数据
create proc tt
as
declare @i int
set @i=0
while(@i<1000000)
begin
insert into news(n_title,n_content) values('sb','dsfsdfsd')
set @i=@i+1
end
exec tt

exec pagination 'news','*','n_id',1000,2,0,0,''


MSSQL分页存储过程,支持连接查询等复杂的查询

调用方法

exec Pagination 'select * from [order] ', 20, 0, 'CreateTime ASC'

exec Pagination 'select * from [order] ', 20, 0, 'CreateTime ASC, Money DESC'

实例过程

CREATE PROCEDURE Pagination
(
@SQL nvarchar(1024), --查询语句
@PageSize int = 20, --分页大小
@PageIndex int = 0, --分页索引
@Sort nvarchar(100) = '', --排序字段
@TotalCount int = 0 output --总数
)
AS

set nocount on
/*声明查询字符串*/
declare @strSQL nvarchar(4000)

set @strSQL = ' select @TotalCount=count(*) from () as t '

/*取得查询结果总数*/
exec sp_executesql
@strSQL,
int=0 OUTPUT',
@TotalCount=@TotalCount OUTPUT

declare @ItemCount int
declare @_PageIndex int

set @_PageIndex = @PageIndex + 1;
/*确定搜索边界*/
set @ItemCount = @TotalCount - @PageSize * @_PageIndex

if(@ItemCount < 0)
set @ItemCount = @ItemCount + @PageSize
else
set @ItemCount = @PageSize

if(@ItemCount < 0) return 1

if(@Sort != '')
begin
/*声明排序变量*/
declare @IndexSort1 nvarchar(50), @IndexSort2 nvarchar(50), @Sort1 nvarchar(50), @Sort2 nvarchar(50)

SET @Sort1 = @Sort
SET @Sort2 = Replace(Replace(Replace(@Sort, 'DESC', ), 'ASC', 'DESC'), , 'ASC')

set @strSQL = 'SELECT * FROM
(SELECT TOP ' + STR(@ItemCount) + ' * FROM
(SELECT TOP ' + STR(@PageSize * @_PageIndex) + ' * FROM
() AS t0
ORDER BY +') AS t1
ORDER BY +') AS t2
ORDER BY '
end
else
begin
set @strSQL = 'SELECT * FROM
(SELECT TOP ' + STR(@ItemCount) + ' * FROM
(SELECT TOP ' + STR(@PageSize * @_PageIndex) + ' * FROM
() As t0)
aS t1)
AS t2'
end

exec sp_executesql
@strSQL
GO
/*
存储过程好处是,函数是mssql内部函数所在运行起来是很快的。
*/?>



文档

二种MSSQL分页存储过程实例应用

二种MSSQL分页存储过程实例应用:二种MSSQL分页存储过程实例应用 二种MSSQL分页存储过程实例应用 MSSQL分页在小型数据网站应用中,不需要用到存存储过程,只有上万百,千万级时就会用到存储过程, 创建存储过程 CREATE PROCEDURE pagination @tblName varchar
推荐度:
标签: 过程 存储 sql
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top