`
zhuyx808
  • 浏览: 123758 次
  • 性别: 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'

分享到:
评论

相关推荐

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

    SQL Server 知识点总结 SQL Server 是一种关系型数据库管理系统,由 Microsoft 开发,广泛应用于企业级数据库管理。下面是 SQL Server 知识点总结,涵盖数据库结构、创建数据库、查看数据库信息、修改数据库等方面...

    SQL Server 基本知识

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

    40集SQL Server 基础入门视频教程 SQL Server 数据库基础入门必备课程

    1.SQL Server 2014简介.mp4 10.SQL Server 2014定义表主键、外键.mp4 11.SQL Server 2014新增表记录.mp4 12.SQL Server 2014查询表记录.mp4 13.SQL Server 2014修改表记录.mp4 14.SQL Server 2014删除表记录....

    sql server2019安装包

    SQL Server 2019是Microsoft推出的一款关系型数据库管理系统,是SQL Server系列中的一个重要版本。它提供了强大的数据存储、...通过掌握SQL Server 2019的相关知识,可以有效提升数据库管理效率和数据驱动决策的能力。

    SqlServer连接工具

    SQL Server连接工具是数据库管理员和开发人员用于与Microsoft SQL Server交互的重要软件。这些工具提供了多种功能,包括数据库的创建、管理、查询、备份、恢复以及性能优化等。在本篇文章中,我们将深入探讨SQL ...

    Sql Server 2014 安装包

    Sql Server 2014 安装包 SQL Server 2014是微软推出的一款关系型数据库管理系统,它在企业级数据管理和分析领域扮演着重要的角色。此安装包包含两个主要组件:SQL Management Studio和SQL Server Express。 1. **...

    SQL Server 18452登录错误

    在“Microsoft SQL Server Management Stdio”中,展开"SQL Server 组",鼠标右键点击 SQL Server 服务器的名称,然后选择"属性",再选择"安全性"选项卡,在"身份验证"下,选择"SQL Server 和 Windows 身份验证模式...

    SQL Server Native Client 10.0

    **SQL Server Native Client 10.0 知识点详解** SQL Server Native Client 10.0 是微软为SQL Server 2008和2008 R2设计的一个数据库访问接口,它集成了ODBC(Open Database Connectivity)和OLE DB(Object Linking...

    SQL Server Native Client 10,以便于SQLserver高版本可以链接SQLserver2000

    压缩包内附带链接服务器创建脚本方式,此SQL Server Native Client 10.0无病毒,有64位和32位可供选择。...安装完SQL Server Native Client 10.0后再创建个链接服务器,可以实现高版本SQLserver远程链接SQLserver2000。

    如何将SQL Server 2005升级到SQL Server 2008

    在将SQL Server 2005升级至SQL Server 2008的过程中,涉及的知识及技巧涵盖了从理解新版本特性到优化、安全、开发、维护高可用性数据库、数据仓库构建和报告服务使用的广泛范围。以下将详细介绍升级过程中需要注意的...

    sqlserver离线安装包

    "sqlserver离线安装包" 提供了这样一种解决方案,使得我们可以在无网络的情况下完成 SQL Server 的部署。 离线安装通常涉及到以下几个关键步骤和知识点: 1. **下载完整安装包**: 要进行离线安装,首先你需要在有...

    sqlserver自动生成sql语句工具sqlserver转oracle

    首先,标题中的"sqlserver自动生成sql语句工具"指的是可以分析SQL Server数据库结构和数据,自动生成对应的SQL创建语句的软件。这种工具通常能帮助数据库管理员快速获取数据库的定义,便于备份、迁移或在其他环境中...

    sql server客户端连接工具

    SQL Server客户端连接工具是数据库管理员和开发人员用来与Microsoft SQL Server进行交互的重要工具。它提供了图形用户界面(GUI)和命令行选项,使得用户能够轻松地执行查询、管理数据库对象以及进行其他数据库维护...

    零点起飞学SQL server

    由于提供的文件信息中,标题和描述均为"零点起飞学SQL server"和"零点起飞学SQLServer",这两部分并没有提供实际的知识内容,而只是表达了一个关于SQL Server学习材料的主题。至于“墨马图书专营店”的重复内容,...

    sql server客户端安装包

    SQL Server客户端安装包是用于与Microsoft SQL Server进行交互的软件组件集合,它包含了连接到SQL Server、执行查询、管理数据库以及进行数据导入导出等任务所需的工具。在本压缩包中,主要包含了一个名为"SQL ...

    Microsoft SQL Server 2005 向后兼容组件SQLServer2005_BC.msi

    SQLServer2005_BC.msi 文件是这个向后兼容组件的安装程序,它包含了用于在更新的SQL Server环境中模拟SQL Server 2005环境的特定库和接口。安装此组件后,用户可以继续使用那些设计时依赖SQL Server 2005特性的应用...

    Spotlight on SQL Server

    1. **SQL Server基础知识**:SQL Server是一个全面的数据库平台,提供数据仓库、在线分析处理(OLAP)和数据挖掘功能,支持多种操作系统环境,如Windows Server。它使用结构化查询语言(SQL)进行数据操作,支持事务...

    SQLServer+ 免安装版

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

    SQL server Native Client 10.0

    SQL Server Native Client 10.0 是微软推出的一款专门用于与SQL Server 2008及后续版本交互的客户端库,它集成了ODBC(Open Database Connectivity)和OLE DB(Object Linking and Embedding, Database)接口。...

Global site tag (gtag.js) - Google Analytics