mssql

推荐列表 站点导航

当前位置:首页 > 数据库 > mssql >

存储过程实现(可带查询条件/万能分页/通用)

来源:网络整理  作者:网络  发布时间:2020-12-12 06:54
可带查询条件的SQL语句的分页存储过程,在项目开发中很实用,感兴趣的朋友可以了解下,希望本文可以巩固你的存储...
+ @tblName + '] where [' + @fldName + ']' + @strTmp + '(['

+ @fldName + '] from [' + @tblName + ']' + @strOrder + ') as tblTmp)'
@OrderType = 1, -- bit
set @strTmp =''
end



@PageIndex = 1, -- int
+ @tblName + ']' + @strTmp + ' ' + @strOrder
begin

复制代码 代码如下:

假设数据库中有张表,表名是UserName,字段分别是ID(int),Name(nvarchar),Age(int)。
CREATE PROCEDURE [dbo].[UP_GetRecordByPage]
if @strWhere != ''
end
@fldName varchar(255), -- 主键字段名
@OrderType bit, -- 设置排序类型, 非 0 值则降序


else

+ @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
下面十二个万能分页存储过程,



AS
declare @strTmp varchar(2000) -- 临时变量(查询条件过长时可能会出错,可修改100为1000)
select ID,Name,Age from myTable where rownum between @min and @max
end
@strWhere = 'Age=13' -- varchar(1000)
+ @tblName + '] where [' + @fldName + ']' + @strTmp + '(['
if @IsReCount != 0
+ @strOrder
set @strOrder = ' order by [' + @fldName +'] desc'
+ @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder
set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
@IsReCount = 0, -- bit
@pageIndex int,
@PageSize int , -- 页尺寸
@fldName = 'ID', -- varchar(255)
end
@PageSize = 2, -- int
with myTable as(select ID,Name,Age,Row_Number() over (order by ID) as rownum from [UserName] )
set @strTmp = ' where ' + @strWhere
set @strOrder = ' order by [' + @fldName +'] asc'

使用方法:

复制代码 代码如下:

这个分页存储过程很不实用,并且表是固定的。
+ @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
exec (@strSQL)
@strWhere varchar(1000) = '' -- 查询条件 (注意: 不要加 where)
set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
if @OrderType != 0
declare @strSQL varchar(6000) -- 主语句
set @strSQL = 'select count(*) as Total from [' + @tblName + ']'+' where ' + @strWhere
begin
EXEC dbo.UP_GetRecordByPage @tblName = ‘UserName', -- varchar(255)
@PageIndex int , -- 页码
set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
@tblName varchar(255), -- 表名
@pageSize int

set @strTmp = '<(select min'
CREATE PROCEDURE [dbo].[UserName]
if @PageIndex <> 0
begin
@IsReCount bit, -- 返回记录总数, 非 0 值则返回
if @strWhere != ''
set @strTmp = '>(select max'
RETURN
+ @fldName + '] from [' + @tblName + '] where ' + @strWhere + ' '
declare @max int;
declare @min int;

复制代码 代码如下:

如果不带查询条件存储过程是:
exec (@strSQL)
declare @strOrder varchar(400) -- 排序类型
set @min=@pageSize*(@pageIndex-1)+1;
begin
AS
set @max=@pageSize*@pageIndex;
如果哪里有不正确的地方,欢迎批评指正,共同进步。

相关热词: 分页

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/sql/mssql/2837.shtml

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

存储过程实现(可带查询条件/万能分页/通用)

2020-12-12 编辑:网络

+ @tblName + '] where [' + @fldName + ']' + @strTmp + '(['

+ @fldName + '] from [' + @tblName + ']' + @strOrder + ') as tblTmp)'
@OrderType = 1, -- bit
set @strTmp =''
end



@PageIndex = 1, -- int
+ @tblName + ']' + @strTmp + ' ' + @strOrder
begin

复制代码 代码如下:

假设数据库中有张表,表名是UserName,字段分别是ID(int),Name(nvarchar),Age(int)。
CREATE PROCEDURE [dbo].[UP_GetRecordByPage]
if @strWhere != ''
end
@fldName varchar(255), -- 主键字段名
@OrderType bit, -- 设置排序类型, 非 0 值则降序


else

+ @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
下面十二个万能分页存储过程,



AS
declare @strTmp varchar(2000) -- 临时变量(查询条件过长时可能会出错,可修改100为1000)
select ID,Name,Age from myTable where rownum between @min and @max
end
@strWhere = 'Age=13' -- varchar(1000)
+ @tblName + '] where [' + @fldName + ']' + @strTmp + '(['
if @IsReCount != 0
+ @strOrder
set @strOrder = ' order by [' + @fldName +'] desc'
+ @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder
set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
@IsReCount = 0, -- bit
@pageIndex int,
@PageSize int , -- 页尺寸
@fldName = 'ID', -- varchar(255)
end
@PageSize = 2, -- int
with myTable as(select ID,Name,Age,Row_Number() over (order by ID) as rownum from [UserName] )
set @strTmp = ' where ' + @strWhere
set @strOrder = ' order by [' + @fldName +'] asc'

使用方法:

复制代码 代码如下:

这个分页存储过程很不实用,并且表是固定的。
+ @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
exec (@strSQL)
@strWhere varchar(1000) = '' -- 查询条件 (注意: 不要加 where)
set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
if @OrderType != 0
declare @strSQL varchar(6000) -- 主语句
set @strSQL = 'select count(*) as Total from [' + @tblName + ']'+' where ' + @strWhere
begin
EXEC dbo.UP_GetRecordByPage @tblName = ‘UserName', -- varchar(255)
@PageIndex int , -- 页码
set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
@tblName varchar(255), -- 表名
@pageSize int

set @strTmp = '<(select min'
CREATE PROCEDURE [dbo].[UserName]
if @PageIndex <> 0
begin
@IsReCount bit, -- 返回记录总数, 非 0 值则返回
if @strWhere != ''
set @strTmp = '>(select max'
RETURN
+ @fldName + '] from [' + @tblName + '] where ' + @strWhere + ' '
declare @max int;
declare @min int;

复制代码 代码如下:

如果不带查询条件存储过程是:
exec (@strSQL)
declare @strOrder varchar(400) -- 排序类型
set @min=@pageSize*(@pageIndex-1)+1;
begin
AS
set @max=@pageSize*@pageIndex;
如果哪里有不正确的地方,欢迎批评指正,共同进步。

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/sql/mssql/2837.shtml

相关文章

风云图片

推荐阅读

返回mssql频道首页