`
- 浏览:
92937 次
- 性别:
- 来自:
杭州
-
邹建的 sql server 分页存储过程 以备用
-
IFOBJECT_ID(N'dbo.pagination')ISNOTNULL
- DROPPROCEDUREdbo.pagination
- GO
-
-
-
-
-
- CREATEPROCdbo.pagination
- @QueryStrnvarchar(4000),--表名、视图名、查询语句
-
@PageSizeint=10,--每页的大小(行数)
-
@PageCurrentint=1,--要显示的页
-
@FdShownvarchar(4000)=N'',--要显示的字段列表,如果查询结果不需要标识字段,需要指定此值,且不包含标识字段
-
@FdOrdernvarchar(1000)=N''--排序字段列表
- AS
- SETNOCOUNTON
- DECLARE
- @FdNamesysname,--表中的主键或表、临时表中的标识列名
- @Id1sysname,--开始和结束的记录号
- @Id2sysname,
-
@Obj_IDint--对象ID
- --表中有复合主键的处理
- DECLARE
- @strfdnvarchar(2000),--复合主键列表
- @strjoinnvarchar(4000),--连接字段
- @strwherenvarchar(2000)--查询条件
- SELECT
- @Obj_ID=OBJECT_ID(@QueryStr),
- @FdShow=CASE
-
WHEN@FdShow>N''THENN''+@FdShow
-
ELSEN'*'
- END,
- @FdOrder=CASE
-
WHEN@FdOrder>N''THENN'ORDERBY'+@FdOrder
-
ELSEN''
- END,
- @QueryStr=CASE
-
WHEN@Obj_IDISNULLTHENN'('+@QueryStr+N')A'
-
ELSEN''+@QueryStr
- END
- --如果显示第一页,可以直接用top来完成
- IF@PageCurrent=1
- BEGIN
- SELECT
- @Id1=CAST(@PageSizeasvarchar(20))
- EXEC(N'
-
SELECTTOP'+@Id1+N'
-
'+@FdShow+N'
-
FROM'+@QueryStr+N'
- '+@FdOrder
- )
- RETURN
- END
- --如果是表,则检查表中是否有标识更或主键
-
IF@Obj_IDISNULLOROBJECTPROPERTY(@Obj_ID,'IsTable')=0
- GOTOlb_usetemp
- ELSE
- BEGIN
- SELECT
- @Id1=CAST(@PageSizeasvarchar(20)),
- @Id2=CAST((@PageCurrent-1)*@PageSizeasvarchar(20))
- --标识列
- SELECT
- @FdName=name
- FROMdbo.syscolumns
- WHEREid=@Obj_ID
- ANDstatus=0x80
- IF@@ROWCOUNT=0--如果表中无标识列,则检查表中是否有主键
- BEGIN
- DECLARE
-
@pk_numberint
- SELECT
-
@strfd=N'',
-
@strjoin=N'',
-
@strwhere=N''
- SELECT
- @strfd=@strfd
-
+N','+QUOTENAME(name),
- @strjoin=@strjoin
-
+N'ANDA.'+QUOTENAME(name)
-
+N'=B.'+QUOTENAME(name),
- @strwhere=@strwhere
-
+N'ANDB.'+QUOTENAME(name)+N'ISNULL'
- FROM(
- SELECT
- IX.id,IX.indid,
- IXC.colid,ixc.keyno,
- C.name
- FROMdbo.sysobjectsO,
- dbo.sysindexesIX,
- dbo.sysindexkeysIXC,
- dbo.syscolumnsC
- WHEREO.parent_obj=@Obj_ID
-
ANDO.xtype='PK'
- ANDO.name=IX.name
- ANDIX.id=@Obj_ID
- ANDIX.id=IXC.id
- ANDIX.indid=IXC.indid
- ANDIXC.id=C.id
- ANDIXC.colid=C.colid
- )A
- ORDERBYkeyno
- SELECT
- @pk_number=@@ROWCOUNT,
-
@strfd=STUFF(@strfd,1,1,N''),
-
@strjoin=STUFF(@strjoin,1,5,N''),
-
@strwhere=STUFF(@strwhere,1,5,N'')
- IF@pk_number=0
- GOTOlb_usetemp--如果表中无主键,则用临时表处理
- ELSEIF@pk_number=1
- BEGIN
- SELECT
- @FdName=@strfd
- GOTOlb_useidentity--使用单一主键
- END
- ELSE
- GOTOlb_usepk--使用复合主键
- END
- END
-
- lb_useidentity:
- EXEC(N'
-
SELECTTOP'+@Id1+N'
-
'+@FdShow+N'
-
FROM'+@QueryStr+N'
-
WHERE'+@FdName+'NOTIN(
-
SELECTTOP'+@Id2+N'
-
'+@FdName+'
-
FROM'+@QueryStr+N'
-
'+@FdOrder+N')
-
'+@FdOrder+N'
- ')
- RETURN
-
- lb_usepk:
- EXEC(N'
- SELECT
-
'+@FdShow+N'
- FROM(
-
SELECTTOP'+@Id1+N'
- A.*
-
FROM'+@QueryStr+N'A
- LEFTJOIN(
-
SELECTTOP'+@Id2+N'
-
'+@strfd+N'
-
FROM'+@QueryStr+N'
-
'+@FdOrder+N'
- )B
-
ON'+@strjoin+N'
-
WHERE'+@strwhere+N'
-
'+@FdOrder+N'
- )A
-
'+@FdOrder+N'
- ')
- RETURN
-
- lb_usetemp:
- SELECT
-
@FdName=QUOTENAME(N'ID_'+CAST(NEWID()asvarchar(40))),
- @Id1=CAST(@PageSize*(@PageCurrent-1)asvarchar(20)),
- @Id2=CAST(@PageSize*@PageCurrent-1asvarchar(20))
- EXEC(N'
- SELECT
-
'+@FdName+N'=IDENTITY(int,0,1),
-
'+@FdShow+N'
- INTO#tb
- FROM(
- SELECTTOP100PERCENT
- *
-
FROM'+@QueryStr+N'
-
'+@FdOrder+N'
- )A
-
'+@FdOrder+N'
- SELECT
-
'+@FdShow+N'
- FROM#tb
-
WHERE'+@FdName+'BETWEEN'+@Id1+'AND'+@Id2+N'
- '
- )
- GO
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
在数据库管理中,分页存储过程是用于处理大量数据并以分页形式展示结果的常见技术。这篇讨论涉及两个分页存储过程的效率比较,其中一个示例存储过程名为`p_page`。`p_page`存储过程的设计允许用户灵活地指定查询参数...
sql server存储过程导出数据到Access文件 原版来源于邹建版本,稍有修改 sql server存储过程导出数据到Access文件
/*–用存储过程实现的分页程序 显示指定表、视图、查询结果的第X页 对于表中主键或标识列的情况,直接从原表取数查询,其它情况使用临时表的方法 如果视图或查询结果中有主键,不推荐此方法 –邹建 2003.09–*/ /*–...
2. **数据库架构**:介绍SQL Server 2000的数据库结构,如表、视图、索引、存储过程、触发器等基本元素,以及它们在数据库设计中的作用。 3. **Transact-SQL(T-SQL)**:这是SQL Server的扩展SQL语法,用于查询、...
邹建-中文版SQL Server2000开发与管理应用实例 一书的目录,可以对照一下 第 1 章 安装和配置SQL Server 1 1.1 SQL Server的版本和版本选择 1 1.2 安装SQL Server的常见问题 3 1.3 如何理解实例 5 ...
邹建的分页存储过程–改了一下 因为邹建的分页存储过程不能返回记录总数,所以每次分页还又要统计一次,所以自己在里面加了个返回记录数,这下就好用了。 @iPageCount int OUTPUT –定义输出变量,放在@QueryStr...
《中文版SQL Server 2000开发与管理应用实例》是邹建撰写的一本专为SQL Server初学者和开发者提供的实战指南。这本书通过丰富的实例,深入浅出地讲解了SQL Server 2000的核心功能和实际操作技巧,旨在帮助读者掌握...
csdn sql server版块超级大版主的开发实例,共15章,包括安装和配置SQL Server、日期处理、字符处理、排序规则、编号处理、数据统计与汇总、分页处理、树形数据处理、数据导入与导出、作业、数据备份与还原。
邹建老师写的《中文版SQL SERVER 2000开发与管理应用实例》。邹健的大名,应该都知道的吧。这本书不怎么清晰,想看清晰的,还是买一下他的书吧。也是对别人劳动的尊重。
7.2.4 使用SQL Server的系统存储过程处理分页 216 7.3 特殊要求的分页处理 217 7.3.1 随机显示的分页处理 217 7.3.2 分类数据的分页处理 221 第 8 章 树形数据处理 223 8.1 单编号处理法 223 ...
存储过程是预编译的SQL语句集合,可提高执行效率,减少网络流量,并封装复杂的业务逻辑。触发器则是在特定数据库操作(如INSERT、UPDATE、DELETE)发生时自动执行的程序,常用于实现业务规则和约束。 安全性是...
源代码中包含了大量T-SQL示例,如SELECT、INSERT、UPDATE和DELETE语句,以及存储过程和触发器的创建。 2. **数据库设计**:实例源代码涵盖了数据库表的设计,包括主键、外键、索引和约束的使用,这有助于理解如何...
csdn sql 版主 邹建 编 你能找到这,不用我详细说明了吧 里面有3个文件 1.Server2000开发与管理应用实例.pdf 2.SQLServer2000开发,管理与应用实例(对应书的代码) 3.深入浅出SQL Server 2005开发,管理与应用实例(这...
csdn sql 版主 邹建 编 你能找到这,不用我详细说明了吧 里面有3个文件 1.Server2000开发与管理应用实例.pdf 2.SQLServer2000开发,管理与应用实例(对应书的代码) 3.深入浅出SQL Server 2005开发,管理与应用实例(这...
很多朋友都遇到过sql死锁问题,本文档就是关于如何解决死锁问题的
6. CSDN邹建的SQL Server博客(http://blog.csdn.net/zjcxc/):CSDN是中国最大的开发者社区之一,邹建的博客是个人专家分享SQL Server知识的平台,有大量实战经验和技巧。 7. CSDN数据库专区...
邹建 2004.4 代码如下: /*–调用示例 exec p_lockinfo1 –*/ alter proc p_lockinfo1 @kill_lock_spid bit=1, –是否杀掉死锁的进程,1 杀掉, 0 仅显示 @show_spid_if_nolock bit=1 –如果没有死锁的进程,是否显示...
csdn sql 版主 邹建 编 你能找到这,不用我详细说明了吧 里面有3个文件 1.Server2000开发与管理应用实例.pdf 2.SQLServer2000开发,管理与应用实例(对应书的代码) 3.深入浅出SQL Server 2005开发,管理与应用实例(这...
转换说明 全角字符从的unicode编码从65281~65374 半角字符从的unicode编码从 33~126 空格比较特殊,全角为 12288,半角为 32 而且除空格外,全角/半角按unicode编码排序在顺序...--邹建 2005.01(引用请保留此信息)--*/
关键词:溅射:辉光放电:溅射沉积功率中图分类号:TN305.92 文献标识码:A 文章编号:1003-353X(2004)04-0019-021 引言在半导体晶片制造过程中,一个重要的工序环节就是金属薄膜沉积,该工艺是作为电路引线用。...