`
zhuyx808
  • 浏览: 120841 次
  • 性别: Icon_minigender_1
  • 来自: 快来看~天上米有灰机
社区版块
存档分类
最新评论

摘别人的sqlserver知识

阅读更多

SQL游标学习

游标一般格式:

DECLARE 游标名称 CURSOR FOR SELECT 字段1,字段2,字段3,... FROM 表名 WHERE ...

OPEN 游标名称

FETCH NEXT FROM 游标名称 INTO 变量名1,变量名2,变量名3,...

WHILE @@FETCH_STATUS=0

         BEGIN

                   SQL语句执行过程... ...

                   FETCH NEXT FROM 游标名称 INTO 变量名1,变量名2,变量名3,...

         END

CLOSE 游标名称

DEALLOCATE 游标名称

例子:

/*
功能:数据库表格tbl_users数据
deptid userid username
1          100      a
1       101      b
2       102      c




要求用一个sql语句输出下面结果
deptid username

1        ab
2         c
[

要求用游标实现]


设计: OK_008
时间: 2006-05
备注:无
*/

create table #Temp1(deptid int,userid int,username varchar(20)) --待测试的数据表

create table #Temp2(deptid int,username varchar(20))                 --结果表

--先把一些待测试的数据插入到待测试表#Temp1

insert into #Temp1

select 1,100,'a' union all

select 1,101,'b' union all

select 1,131,'d' union all

select 1,201,'f' union all

select 2,302,'c' union all

select 2,202,'a' union all

select 2,221,'e' union all

select 3,102,'y' union all

select 3,302,'e' union all

select 3,121,'t'

--

declare @deptid int,@username varchar(20)

--定义游标

declare Select_cursor cursor for

         select deptid,username from #Temp1

open Select_cursor

fetch next from Select_cursor into @deptid,@username     --提取操作的列数据放到局部变量中

while @@fetch_status=0      --返回被 FETCH 语句执行的最后游标的状态

/*

@@FETCH_STATUS =0           FETCH 语句成功

@@FETCH_STATUS =-1 FETCH 语句失败或此行不在结果集中

@@FETCH_STATUS =-2 被提取的行不存在

*/

         begin

                   --当表#Temp2deptid存在相同的数据时,就直接在列username上追加@username

                  if(exists(select * from #Temp2 where deptid=@deptid ))

                            update #Temp2 set username=username +@username where deptid=@deptid

                   else

                   --插入新数据

                            insert into #Temp2 select @deptid,@username

                   fetch next from Select_cursor into @deptid,@username

         end

close Select_cursor      

deallocate Select_cursor

select * from #Temp2 --测试结果

Drop table #Temp1,#Temp2

 

自动生成表的更新数据的存储过程

设计原因在数据库设计中,有时候建立了很多表,每个表都有InsertUpdateDelete结构基本相同的存储,要是能有个自动生成表的更新数据的存储过程,就方便了我们不必浪费时间去写每一张表的InsertUpdateDelete存储过程。

设计方法先提取表的各字段信息,包含字段的数据类型、数据定义长度、是否主键等。再根据提取出来的信息构造成表的更新数据的存储过程。下面的方法是有一个用户自定义函数FN_GetObjColInfo和一个存储过程SP_CreateProcdure来实现

 

用户自定义函数FN_GetObjColInfo

 

/*

功能:返回某一表的所有字段、存储过程、函数的参数信息

设计:OK_008

时间:2006-05

*/

CREATE FUNCTION FN_GetObjColInfo

(@ObjName varchar(50))

RETURNS  @Return_Table TABLE(

                   TName nvarchar(50),

                   TypeName nvarchar(50),

                   TypeLength nvarchar(50),

                   Colstat       Bit

                   ) 

AS 

BEGIN

         INSERT  @Return_Table

                   /*

                   主要是从系统表中提取表(对象)的各字段信息。

                   sysobjects: 在数据库内创建的每个对象(约束、默认值、日志、规则、存储过程等)在表中占一行

                   syscolumns:每个表和视图中的每列在表中占一行,存储过程中的每个参数在表中也占一行

                   systypes: 保存数据类型和用户定义数据类型

                   */

                   select b.name as 字段名,c.name as 字段类型,b.length/2 as 字段长度,b.colstat as 是否自动增长

                   from sysobjects a

                   inner join syscolumns b on a.id=b.id

                   inner join systypes c on c.xusertype=b.xtype

                   where a.name =@ObjName

                   order by  B.ColID

         RETURN

END

GO

存储过程SP_CreateProcdure

 

 

 

 

CREATE PROCEDURE SP_CreateProcdure

@TableName nvarchar(50)

 AS

/*

功能: 自动生成表的更新数据的存储过程

              如:当建立表MyTable后,执行SP_CreateProcdure ,生成表MyTable的数据更

                 新的存储过程UP_MyTable

设计: OK_008

时间: 2006-05

备注:

         1、请在查询分析器上执行:EXEC SP_CreateProcdure TableName

         2、由于生成的字符串长度合计很多时候存在>4000以上,所有只使用Print输出,

               Copy即可。

         3、该方法能生成一般表的更新数据的存储过程,其中更新格式可以根据实际

               情况修改。

设计方法:

         1、提取表的各个字段信息

         2 ──┰─ 构造更新数据过程

                 ├─ 构造存储过程参数部分

                 ├─ 构造新增数据部分

           ├─ 构造更新数据部分

                 ├─ 构造删除数据部分

         3、分段PRINT

         4、把输出来的结果复制到新建立存储过程界面中即可使用。

*/

DECLARE @strParameter nvarchar(3000)

DECLARE @strInsert nvarchar(3000)

DECLARE @strUpdate nvarchar(3000)

DECLARE @strDelete nvarchar(500)

DECLARE @strWhere  nvarchar(100)

DECLARE @strNewID  nvarchar(100)

DECLARE @SQL_CreateProc nvarchar(4000)

 

SET @SQL_CreateProc='CREATE PROCEDURE UP_'+@TableName +char(13)+'@INTUpdateID int,' +' /* -1 删除  0 修改  1新增 */'

SET @strParameter=''

SET @strInsert=''

SET @strUpdate=''

SET @strWhere=''

 

DECLARE @TName nvarchar(50),@TypeName nvarchar(50),@TypeLength nvarchar(50),@Colstat bit

DECLARE Obj_Cursor CURSOR FOR

SELECT * FROM  FN_GetObjColInfo(@TableName)

OPEN Obj_Cursor

FETCH NEXT FROM Obj_Cursor INTO @TName,@TypeName,@TypeLength,@Colstat

WHILE @@FETCH_STATUS=0

  BEGIN

         --构造存储过程参数部分

         SET @strParameter=@strParameter +CHAR(13)+'@'+ @TName + ' ' +@TypeName+

                                     (CASE

                                     WHEN @TypeName='nvarchar' THEN '('+@TypeLength+')'

                                     ELSE ''

                                     END)+','

         --构造新增数据部分

         IF @Colstat=0 SET @strInsert=@strInsert + '@'+ @TName  +','

         --构造更新数据部分

         IF (@strWhere='')

            BEGIN

                   IF @Colstat=0 SET @strNewID='SET @'+@TName+'=(Select ISNULL(MAX('+@TName+'),0) From '+@TableName+')+1    --取新的ID'

分享到:
评论

相关推荐

    SQL Server 知识大全

    SQL Server 知识大全

    SQL Server 基本知识

    第二讲: SQL Server 基本知识 教师课件搬运,非原创,今后也要好好加油~

    SQL server 的知识总结

    自己总结,非常适合初学者对整个SQLserver知识的整体归纳,已经学习步骤。

    SQLServer+ 免安装版

    SQLServer+ 免安装版 SQLServer+是在原有SQLServer2000的基础上改善了数据库安装的繁锁性,让软件企业在发布基于SQLServer2000数据库软件的时候,只要把软件打包进入安装包而不需要再单独安装数据库,也不需要另外...

    [SQL Server] Microsoft SQL Server 2012 技术内幕 (英文版)

    [Microsoft Press] Microsoft SQL Server 2012 技术内幕 (英文版) [Microsoft Press] Microsoft SQL Server 2012 Internals (E-Book) ☆ 图书概要:☆ Dive deep inside the architecture of SQL Server 2012 ...

    Microsoft SQL Server 2008 R2 SP1 Native Client

    Microsoft SQL Server 2008 Native Client (SQL Server Native Client) 是单一动态链接库 (DLL),其中包含 SQL OLE DB 提供者和 SQL ODBC 驱动程序。此链接库针对使用机器码 API (ODBC、OLE DB 和 ADO) 的应用程序...

    SQL Server基础知识(html)

    SQL Server基础知识(html),SQL Server基础知识(html),SQL Server基础知识(html)

    SqlServer知识点总结

    本人的一点SQL知识总结。

    SqlServer连接工具

    SqlServer连接工具SqlServer连接工具SqlServer连接工具

    完美SQL Server绿色版

    SQLServer文件, 否则后果自负。作者不为您承担任何方面的任何责任。 SQL Server 2000绿色版注意事项 --------------------------- 1 本地连接服务器请使用界面中“服务器名”文本框中的文本作为服务器名连接...

    sqlserver知识点总结(考试复习必备)

    超详细的sqlserver笔记总结(考试复习必备)

    Sql Server知识点全集

    一个全面、详细的Sql Server2000的知识点集合。里面涉及了从最基本的建数据库、表, 到较为麻烦的事务、约束、触发器等,从简单到复杂层层递进,很实用,会是你理想的帮手...

    常用sqlserver知识讲解

    sql server 技术详解,学习资料;包含基本语法、函数、数据类型、存储过程、触发器等语法规则的详细解析,新手入门必备资料

    SQL Server 2014基础入门视频教程 (40集,含课件)

    SQL Server 2014基础入门视频教程 (40集,含课件) 1.SQL Server 2014简介.mp4 2.SQL Server 2014硬件和软件要求.mp4 3.SQL Server 2014数据库安装.mp4 4.SQL Server 2014数据库创建.mp4 5.SQL Server 2014...

    sqlserver离线安装包

    sqlserver离线安装包

    SQL Server 2016 KEY

    SQL Server 2016 Web BXJTY-X3GNH-WHTHG-8V3XK SQL Server 2016 Standard B9GQY-GBG4J-282NY-QRG4X SQL Server 2016 Enterprise Core TBR8B-BXC4Y-298NV-PYTBY SQL Server 2016 Enterprise MDCJV-3YX8N-WG89M-KV443...

    sql server 2008 安装教程

    sql server 2008 安装教程sql server 2008 安装教程sql server 2008 安装教程sql server 2008 安装教程sql server 2008 安装教程

    支持navicate 连接 sqlserver 2019 的 驱动sqlserver native client 11.0

    支持navicate 连接 sqlserver 2019 的 驱动sqlserver native client 11.0 ,亲测可用,ssms自带的不能连接,会报远程关闭错误。

    sql server ce server tools

    SQL Server 2005 移动版(SQL Server Mobile)或SQL Server 2000 Windows CE 2.0版(SQL Server CE 2.0)的企业和个人用户如果计划与SQL Server 2000或SQL Server 2005数据库保持同步,需要在您运行Microsoft ...

    SqlServer基础知识总结.pdf

    SqlServer基础知识总结.pdf

Global site tag (gtag.js) - Google Analytics