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
查看全文
相关阅读:
MySQL my.cnf详解
函数:sleep-exit-wait
fork-小实验
OS-进程调度
CET-4流程
SDK和API的区别
生活-金钱管理-不是理财
算法设计与分析:Strassen矩阵乘法
力扣:二进制加法求和
算法设计与分析:大整数乘法
原文地址:https://www.cnblogs.com/snowball/p/1039689.html
最新文章
浏览器下载服务端文件
使用JS定时弹出广告
使用javascript实现图片轮播效果
迭代器和生成器
集合介绍
多线程之同步与死锁问题
多线程的创建的使用
大数据之文件的压缩和解压缩
大数据开发之文件归档和解归档
装饰器
热门文章
使用Python来处理文件
干掉Oracle死锁进程
oracle自带脚本说明(rdbms,ctx,sqlplus,javavm)
MySQL慢查询分析工具之mysqldumpslow
使用MySQL闪回工具binlog2sql
Oracle 19c安装流程
MySQL主从复制参数注解
Oracle锁处理、解锁方法
Oracle Data Guard技术原理
InnoDB如何避免ibdata1文件突然增长
Copyright © 2011-2022 走看看