SQL存储过程语句

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

CREATE proc getdataset

@TableList Varchar(200)='*',--搜索表的字段,比如:’id,datatime,job‘,用逗号隔开

@TableName Varchar(30), --搜索的表名

@SelectWhere Varchar(500)='',--搜索条件,这里不用写where,比如:job=’teacher‘and class='2'

@SelectOrderId Varchar(20),--表主键字段名。比如:id

@SelectOrder Varchar(200)='', --排序,可以使用多字段排序但主键字段必需在最前面.也可以不写,比如:order by class asc

@intPageNo int=1, --页号

@intPageSize int=10 ,--每页显示数

@RecordCount int OUTPUT --总记录数(存储过程输出参数)

as

declare @TmpSelect NVarchar(600)

declare @Tmp NVarchar(600)

set nocount on--关闭计数

set @TmpSelect = 'select @RecordCount = count(*) from '+@TableName+' '+@SelectWhere

execute sp_executesql

@TmpSelect, --执行上面的sql语句

N'@RecordCount int OUTPUT' , --执行输出数据的sql语句,output出总记录数

@RecordCount OUTPUT

if (@RecordCount = 0) --如果没有贴子,则返回零

return 0

/*判断页数是否正确*/

if (@intPageNo - 1) * @intPageSize > @RecordCount --页号大于总页数,返回错误

return (-1)

set nocount off--打开计数

if @SelectWhere != ''

begin

set @TmpSelect = 'select top '+str(@intPageSize)+' '+@TableList+' from '+@TableName+' where '+@SelectOrderId+' not in(select top '+str((@intPageNo-1)*@intPageSize)+'

'+@SelectOrderId+' from '+@TableName+' '+@SelectWhere +' '+@SelectOrder+') and

'+@SelectWhere +' '+@SelectOrder

end

else

begin

set @TmpSelect = 'select top '+str(@intPageSize)+' '+@TableList+' from '+@TableName+' where '+@SelectOrderId+' not in(select top '+str((@intPageNo-1)*@intPageSize)+'

'+@SelectOrderId+' from '+@TableName+' '+@SelectOrder+') '+@SelectOrder

end

execute sp_executesql @TmpSelect

return(@@rowcount)

GO

其实代码也很简单,学编程的人基本上都是懂数据库的,这个存储过程估计不是问题。

其他的代码我都做了解释,有颜色的那段我没有解释,我在这里解释一下。其实也很简单,大家来看:

select top '+str((@intPageNo-1)*@intPageSize)+' '+@SelectOrderId+' from '+@Tabl eName+' '+@SelectWhere +' '+@SelectOrder+'

这段代码的执行结果是什么了,是不是当前页前面的主键的集合啊,现在我们从所有的表中选出主键的值不在这个结果的之内的pagesize个记录不就是当前页的内容了吗?

2.aspx页面就不用再将了吧?我这里将代码写上:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="aa.aspx.cs" Inherits="_Default" %>

"/TR/xhtml1/DTD/xhtml1-transitional.dtd">

无标题页

Height="180px" Width="867px">

首页

上一页

下一页

尾页

页,

相关文档
最新文档