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
查看全文
相关阅读:
其它 Surface 重装系统 win10
电商 商品数据分析 市场洞察 导出数据后 横线对比 python实现2
电商 商品数据分析 市场洞察 导出数据后 横线对比 python实现
电商 商品数据分析 市场洞察 导出数据后 横线对比
Python excel转换为json
关于四舍五入
MBProgressHUD 显示后,为何不能点击屏幕其他地方
使用容器挂载NFS
luogu P1128 [HNOI2001]求正整数 dp 高精度
EC R 86 D Multiple Testcases 构造 贪心 二分
原文地址:https://www.cnblogs.com/snowball/p/1039689.html
最新文章
EF中的查询方法
EF中的持久化场景
EF中的实体关系
java 中 Math类
Map接口----Map中嵌套Map
Math java
for 循环增强
处理帧数不等的视频的批处理代码
线性回归:Sklearn与Excel
Torch:从特征提取到模型的语音识别
热门文章
用PyTorch重新创建Keras API
在30分钟内创建你的深度学习服务器
使用OpenCV和Python构建自己的车辆检测模型
使用TensorFlow Hub进行神经风格迁移
数据科学速成班:解释逻辑回归
版本控制工具 Git SourceTree 登录信息等被我删除了 解决
电商 心心验货 心心美妆鉴定
接口 一些基本概念
电商 笔记
接口 C# abp 接口在web层 swagger
Copyright © 2011-2022 走看看