当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 谈SQL Server 2005中的T-SQL增强

MSSQL
SQL Server中常使用的DBCC命令
Windows2003服务器安装设置教程:MSSQL安全篇
MySql教程:两个表之间更新数据
asp.net网站开发中使用Sqlite嵌入式数据库
Microsoft SQL Server SA权限安全
SQL Server帐号孤立的问题解决
SQL server教程:SQL语法
修复MSSQLSERVER数据库置疑的步骤
安全基础知识 细说暴库的原理与方法
MSSQL和Mysql自定义函数与存储过程
MSSQL数据库不能手动创建新的连接
ASP连接MSSQL的错误: 拒绝访问
MSSQL数据库镜像在Oracle中是如何实现的
写给菜鸟站长:解读你的茫然
教你创建动态MSSQL数据库表
MSSQL下用UNION和系统表配合猜表名和字段名深度注入
Public权限下的列目录
phpBB 3.0.6 RC1简单介绍和下载
SQL Server:SQL中如何正确认识触发器
SQL Server:如何正确理解存储过程

MSSQL 中的 谈SQL Server 2005中的T-SQL增强


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 125 ::
收藏到网摘: n/a

SQL Server 2005中的T-SQL增强(一)

丰富的数据类型 Richer Data Types

1、varchar(max)、nvarchar(max)和varbinary(max)数据类型最多可以保存2GB的数据,可以取代text、ntext或image数据类型。

CREATE TABLE myTable(id INT,content VARCHAR(MAX))

2、XML数据类型

XML数据类型允许用户在SQL Server数据库中保存XML片段或文档。

错误处理 Error Handling

1、新的异常处理结构

2、可以捕获和处理过去会导致批处理终止的错误。前提是这些错误不会导致连接中断(通常是严重程度为21以上的错误,例如,表或数据库完整性可疑、硬件错误等等。)。

3、TRY/CATCH 构造

SET XACT_ABORT ONBEGIN TRY<core logic>END TRYBEGIN CATCH TRAN_ABORT<exception handling logic>END TRY@@error may be quired as first statement in CATCH block

4、演示代码

USE demoGO--创建工作表CREATE TABLE student(stuid INT NOT NULL PRIMARY KEY,stuname VARCHAR(50))CREATE TABLE score(stuid INT NOT NULL REFERENCES student(stuid),score INT)GOINSERT INTO student VALUES (101,'zhangsan')INSERT INTO student VALUES (102,'wangwu')INSERT INTO student VALUES (103,'lishi')INSERT INTO student VALUES (104,'maliu')--调用一个运行时错误SET XACT_ABORT OFFBEGIN TRANINSERT INTO score VALUES (101,90)INSERT INTO score VALUES (102,78)INSERT INTO score VALUES (107, 76) /* 外键错误 */INSERT INTO score VALUES (103,81)INSERT INTO score VALUES (104,65)COMMIT TRANGOSELECT * FROM studentSELECT * FROM score--使用TRY...CATCH构造,并调用一个运行时错误SET XACT_ABORT OFFBEGIN TRYBEGIN TRANINSERT INTO score VALUES (101,90)INSERT INTO score VALUES (102,78)INSERT INTO score VALUES (107, 76) /* 外键错误 */INSERT INTO score VALUES (103,81)INSERT INTO score VALUES (104,65)COMMIT TRANPRINT '事务提交'END TRYBEGIN CATCHROLLBACKPRINT '事务回滚'SELECT ERROR_NUMBER() AS ErrorNumber,ERROR_SEVERITY() AS ErrorSeverity,ERROR_STATE() as ErrorState,ERROR_MESSAGE() as ErrorMessage;END CATCHGOSELECT * FROM scoreGO

快照隔离 Snapshot Isolation

1、写入程序不会阻碍读取程序

2、新的隔离级别提供了以下优点:

评论 (0) All

登陆 还没注册?