zoukankan
html css js c++ java
通用数据库存储过程代码高效分页存储过程
--
获取指定页的数据
Create
PROCEDURE
pagination
@tblName
varchar
(
255
),
--
表名
@strGetFields
varchar
(
1000
)
=
'
*
'
,
--
需要返回的列
@fldName
varchar
(
255
)
=
''
,
--
排序的字段名
@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
)
--
排序类型
if
@doCount
!=
0
begin
if
@strWhere
!=
''
set
@strSQL
=
"
select
count
(
*
)
as
Total
from
[
" + @tblName + "
]
where
"
+
@strWhere
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
)
+
" "
+
@strGetFields
+
"
from
[
" + @tblName + "
]
where
"
+
@strWhere
+
" "
+
@strOrder
else
set
@strSQL
=
"
select
top
"
+
str
(
@PageSize
)
+
" "
+
@strGetFields
+
"
from
[
"+ @tblName + "
]
"
+
@strOrder
--
如果是第一页就执行以上代码,这样会加快执行速度
end
else
begin
--
以下代码赋予了@strSQL以真正执行的SQL代码
set
@strSQL
=
"
select
top
"
+
str
(
@PageSize
)
+
" "
+
@strGetFields
+
"
from
[
"
+ @tblName + "
]
where
[
" + @fldName + "
]
"
+
@strTmp
+
"(
[
"+ @fldName + "
]
)
from
(
select
top
"
+
str
((
@PageIndex
-
1
)
*
@PageSize
)
+
"
[
"+ @fldName + "
]
from
[
" + @tblName + "
]
"
+
@strOrder
+
")
as
tblTmp)"
+
@strOrder
if
@strWhere
!=
''
set
@strSQL
=
"
select
top
"
+
str
(
@PageSize
)
+
" "
+
@strGetFields
+
"
from
[
"
+ @tblName + "
]
where
[
" + @fldName + "
]
"
+
@strTmp
+
"(
[
"
+ @fldName + "
]
)
from
(
select
top
"
+
str
((
@PageIndex
-
1
)
*
@PageSize
)
+
"
[
"
+ @fldName + "
]
from
[
" + @tblName + "
]
where
"
+
@strWhere
+
" "
+
@strOrder
+
")
as
tblTmp)
and
"
+
@strWhere
+
" "
+
@strOrder
end
end
exec
(
@strSQL
)
GO
Dynamic Sql
Code
declare
@ParameterC
nvarchar
(
100
)
exec
SP_EXECUTESQL
N
'
select @ParameterA,@ParameterB
'
,
N
'
@ParameterA int,@ParameterB int
'
,
@Parametera
=
1
,
@Parameterb
=
2
select
@ParameterC
declare
@sql
nvarchar
(
100
)
declare
@R
nvarchar
(
100
)
declare
@ParameterA
int
--
set @SQL= N'select @R=11,@ParameterA'
--
exec SP_EXECUTESQL @SQL, N' @R BIGINT OUTPUT,@ParameterA int', @R OUTPUT,@ParameterA=123
set
@SQL
=
N
'
select @R=11
'
exec
SP_EXECUTESQL
@SQL
, N
'
@R BIGINT OUTPUT
'
,
@R
OUTPUT
select
@R
查看全文
相关阅读:
中国大陆地区用户请特别注意:请勿存放违反当地法律法规文件
JAVA日报
JAVA日报
JAVA日报
JAVA日报
JAVA日报
JAVA日报
JAVA日报
JAVA日报
JAVA日报
原文地址:https://www.cnblogs.com/snowball/p/1039689.html
最新文章
C++字符串
C++基础(1)
文件上传下载
oracle高级查询
修改原生CheckBox的样式
Mybatis缓存
权限器具
属性访问器兼容IE,使用VBScript
mint系统安装
temp test
热门文章
IO、阻塞和非阻塞、目录
关于目前的存在的两点故障
透明度报告
关于6月24日维护的补偿措施
我们仍在维护一些服务
我们将于2020年6月25日进行维护
我们将于2020年6月25日进行维护
订阅相关帮助
UWP客户端可能导致无法下载文件
欧盟用户请注意:我们尚未符合欧盟数据保护通用条例(GPDR)
Copyright © 2011-2022 走看看