数据库相关之SQL Server(一)

server|数据|数据库

1.1、高级查询语句
1、  TRUNCATE TABLE [table_name]

删除表中的所有行,而不记录单个行删除操作。

TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少。

DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。

新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用 DELETE。

对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE,而应使用不带 WHERE 子句的 DELETE 语句。由于 TRUNCATE TABLE 不记录在日志中,所以它不能激活触发器。

2、  SP_DATABASES

返回在 sysdatabases 系统表中列出的数据库。

sp_databases 在开放式数据库连接 (ODBC) 中没有等价的过程。

3、  SP_DATATYPE_INFO

    sp_datatype_info 等价于 ODBC 中的 SQLGetTypeInfo。返回结果按 DATA_TYPE 排序,再按数据类型映射为相应 ODBC SQL 数据类型的紧密程度进行排序。

4、  SP_COLUMNS

        返回当前环境中可查询的指定表或视图的列信息。

           Sp_columns [table_name]

              Or:sp_columns @table_name = '[table_name]', @column_name = '[column_name]'

5、  SP_TABLES

    用法同上,不再雷述。
1.2、存储过程
       所有设计优良的 Microsoft SQL Server 2000 应用程序都应当使用存储过程。不论是否将应用程序的业务逻辑写入存储过程都应如此。甚至连没有业务逻辑组件的标准 Transact-SQL 语句,在用参数打包成存储过程后也能获得性能收益。编译进存储过程的 Transact-SQL 语句在执行时可省去大量的处理。
1.2.1存储过程的设计规则
l         CREATE PROCEDURE 定义本身可包括除下列 CREATE 语句以外的任何数量和类型的 SQL 语句,存储过程中的任意地方都不能使用下列语句:

CREATE DEFAULT

CREATE TRIGGER

CREATE PROCEDURE

CREATE VIEW

CREATE RULE

 

l         存储过程中参数的最大数目为 2100。

l         可以在存储过程内引用临时表。

l         如果在存储过程内创建本地临时表,则该临时表仅为该存储过程而存在;退出该存储过程后,临时表即会消失。
1.2.2创建存储过程
示例:

CREATE PROCEDURE [PR_insert_casebrief_NEW]

@p_Casebrief_code as varchar(50),@p_Object_id as integer,@p_Spy_starttime as datetime,

@p_Spy_endtime as datetime,@p_Casebrief_id as integer out

as

insert into Case_brief_telecom(Casebrief_code,object_id,Spy_starttime,Spy_endtime,)

values(@p_Casebrief_code,@p_Object_id,@p_Spy_starttime,@p_Spy_endtime)

select @p_Casebrief_id = @@identity

GO

**** p_Casebrief_id为该表的主键,自动增长。

l         Microsoft SQL Server 2000 存储过程以四种方式返回数据:

1、输出参数,既可以返回数据(整型值或字符值等),也可以返回游标变量(游标是可以逐行检索的结果集)。

2、返回代码,始终是整型值。

3、SELECT 语句的结果集,这些语句包含在该存储过程内或该存储过程所调用的任何其它存储过程内。

4、可从存储过程外引用的全局游标。

l         当一个存储过程调用另一个存储过程时,存储过程就会嵌套。存储过程最多可以嵌套 32 级。被调用存储过程开始执行时,嵌套级数增加一级;被调用存储过程完成执行时,嵌套级数减少一级。试图超出 32 级的最高嵌套级数时,将导致整个存储过程调用链的失败。正在执行的存储过程的当前嵌套级数存储在 @@NESTLEVEL 函数中。

l         存储过程中使用游标:
 

CREATE procedure XG_Insert_XXX

as 

declare @object_id as int

declare @CaseBriefID as varchar(4)

declare @number_style as varchar(50)

declare @strNumberType2 as varchar(50)

declare @number_code as varchar(50)

declare @strSQL as varchar(1000)

declare @strSQL1 as varchar(255)

declare @brief_code as varchar(50)

declare @creator as varchar(50)

declare @BH as varchar(50)

 

    DECLARE OBJECT_CURSOR CURSOR

    FOR SELECT distinct object_id,CaseBrief_ID,casebrief_code,table_creator from case_XXX

 

    OPEN OBJECT_CURSOR

    FETCH NEXT FROM OBJECT_CURSOR INTO @object_id,@CaseBriefID,@brief_code,@creator

    while (@@FETCH_STATUS = 0)

    BEGIN

        SELECT @BH=FullCode from View_user_depID where LoginName=''+@creator+''

        print @BH

        DECLARE NUMBER_CURSOR CURSOR

        FOR SELECT distinct number_style,number_code from case_XXX where object_id=@object_id

 

        OPEN NUMBER_CURSOR

        FETCH NEXT FROM NUMBER_CURSOR INTO @number_style,@number_code

        while (@@FETCH_STATUS = 0)

        BEGIN          

            set @strSQL='insert into CASE_XXX(CASEBRIEF_ID,NUM_TYPE,NUMBER) values(' + @CaseBriefID + ','''+ @number_style + ''',''' + @number_code + ''')'

            exec(@strSQL)

            FETCH NEXT FROM NUMBER_CURSOR INTO @number_style,@number_code

        END

        CLOSE NUMBER_CURSOR

        DEALLOCATE NUMBER_CURSOR

        FETCH NEXT FROM OBJECT_CURSOR INTO @object_id,@CaseBriefID,@brief_code,@creator

    END

    CLOSE OBJECT_CURSOR

    DEALLOCATE OBJECT_CURSOR

GO

时间: 2024-09-17 04:42:49

数据库相关之SQL Server(一)的相关文章

数据库移植到SQL Server 2008R2出现“3145错误”怎么办

  SQL Server 2000数据库移植到SQL Server 2008R2数据库服务器中碰到的"3145错误"及解决办法 辛苦忙碌了一个星期终于安装配置好了TFS服务器,给每个团队成员分配了账户和邮箱.不过,老机器中的部分数据需要备份到新机器中,其中在移植一个使用DVBBS架设的论坛的时候,出了点问题,记录如下,以备查找,也希望能帮助到其他人. 由于论坛已经运行了一段时间,包括公司注册用户.相关讨论共享等重要资料,需要将其移植到新安装TFS服务器的机器上,并对外公开访问权限.旧的

将ACCESS的数据库转化为SQL SERVER的数据库的几点体验

access|server|数据|数据库 最近忙于将ACCESS的数据库转化为SQL SERVER的数据库的学习,从中摸索出几条经验,与大家分享.1.ACCESS的数据库中的自动编号类型在转化时,sql server并没有将它设为自动编号型,我们需在SQL创建语句中加上identity,表示自动编号!2.转化时,跟日期有关的字段,SQL SERVER默认为smalldatetime型,我们最好将它变为datetime型,因为datetime型的范围比smalldatetime型大.我遇见这种情况

转换数据库-数据库:Oracle数据库转换成SQL server数据库

问题描述 数据库:Oracle数据库转换成SQL server数据库 把oracle数据库转换成SQL server数据库(2008 r2)版本的,数据迁移,大概百万条数据,有什么好的办法或者是执行语句嘛: 解决方案 我只知道可以把脚本倒出来 然后在sql中执行 解决方案二: http://wenku.baidu.com/link?url=TA7z0XmVyfKHyTQqiPwE6gAdkKbFG7ngBBL75mvjbRbAGFVElPyxOLFSvNT4YskRl8KLdeVdOlHc8a6

数据库服务器安装的sql server是哪个?

问题描述 数据库服务器安装的sql server是哪个? 请问各位SQL Server 2008 R2 Enterprise 和SQL Server 2008 R2 Express with Management Tools有什么区别啊?在服务器上该安装哪个? 解决方案 SQL Server跨服务器操作数据库SQL Server 中的服务器和数据库角色 (ADO.NET)SQL SERVER 数据库链接服务器总结 解决方案二: SQL Server 2008 R2 Enterprise Expr

SQL Server 2000数据库升级到SQL Server 2005的最快速

安装了sql server 2005以后,不管是32位还是64位,都可以直接附加sql server 2000下创建的数据库文件.数据库升级到2005的最快速的方法是:在SQL Server 2000中分离数据库,将数据库文件拷到装有SQL Server 2005的机器上,然后在Management Studio中附加数据库,附加的时候会出现孤立用户,可以用下面的语句把孤立用户和数据库用户做关联: sp_change_users_login 'update_one', 'test', 'test

ASP.NET2.0数据库入门之SQL Server

asp.net|server|sql|数据|数据库 因为Access并不真正为高性能应用程序服务,所以一个希望有多个同时连接用户的站点必须部署一个比Access更适合的数据源.本文将讲述如何从Microsoft SQL Server(一种企业级RDMS)中获取数据. SQL Server完全版包括了三个部分.第一个是引擎,用于实际组织数据以及针对命令响应进行读取和写入操作.第二个是开发人员的工具软件包,用于对数据库进行操作,例如Query Analyzer和Data Transformation

将Access数据库移植到SQL Server[摘]

access|server|数据|数据库 随着用户对于企业级高性能数据库的需求的增长,用户时常要从Microsoft Access Jet引擎的文件-服务器环境下转换到Microsoft SQL Server的客户-服务器环境.Microsoft Office 2000中的Access 2000 Upsizing Wizard可实现将数据表和查询转移到SQL Server 7.0中.如果您用的是Access的较早的版本,您可以先将它升级为Access 2000,然后再使用其中的Upsizing

将Access数据库移植到SQL Server 7.0

access|server|数据|数据库 随着用户对于企业级高性能数据库的需求的增长,用户时常要从Microsoft Access Jet引擎的文件-服务器环境下转换到 Microsoft SQL Server的客户-服务器环境.Microsoft Office 2000中的Access 2000 Upsizing Wizard可实现将数据表和 查询转移到SQL Server 7.0中.如果您用的是Access的较早的版本,您可以先将它升级为Access 2000,然后再使用其中的 Upsizi

mfc vc6 0 sql 数据库-请问当SQL Server数据库中数据有更新的时候,如何通知到MFC上?

问题描述 请问当SQL Server数据库中数据有更新的时候,如何通知到MFC上? 编程环境VC6.0,在MFC对话框中添加了一些控件,并且能够显示数据库中内容, 使用的是CRecordSet类,读取完数据库后就调用Close关闭数据库了. 我想请问的是,如何实时的显示数据库内容? 或者当数据库数据有变更的时候才显示到 MFC的控件上? 解决方案 参考这个试试 SQL Server 2008 表数据改变后发送消息 http://blog.csdn.net/sliphades/article/de