当前位置: 首页 > 图文教程 > 数据库 > MSSQL > SQL技巧:探索用户自定义数据类型

MSSQL
SQL Server 中死锁产生的原因及解决办法
教你在SQL Server 2000数据库中使用分区
数据仓库基本报表制作过程中的SQL写法
自动定时重启sql server回收内存
轻松解决SQL Server 2005中的常见问题
用一个案例讲解SQL Server数据库恢复
安装SQL Server 2005时出现计数器错误
讲解SQL Server 2005数据库的同义词Bug
利用SQL语句对不同数据库进行高效果分页
三种数据库利用SQL语句进行高效果分页
数据库连接字符串的常见问题和解决方法
教你快速掌握一些方便易用的SQL语句
深入分析SQL Server的数据转换服务
系统默认的MySQL用户名消失的解决方法
SQL 2008邮件故障排除:发送测试电子邮件
SQL Server 2005日志文件损坏的处理方法
在SQL Server 2005数据库中进行错误捕捉
SQL Server查询速度慢原因及优化方法
加密SQL Anywhere 提升政府行业数据安全
Windows Server 2008之数据安全保护

MSSQL 中的 SQL技巧:探索用户自定义数据类型


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

用户自定义数据类型是一个确保数据库中域与数据紧密结合的好办法。数据的类型可能在整个数据库中都是一致的,每个数据的适用范围和它的数据类型是相关联的。sp_bindrule过程是一个向后兼容过程,该过程为数据类型确定了一个适用范围。CREATE RULE命令也是一个向后兼容命令,为域值的遵守产生了一个规则。该规则可以被限制为用户自定义的数据类型。CREATE DEFAULT也是一个向后兼容命令,而且也可以被限制为用户自定义的数据类型。

这些向后兼容命令都是由Sybase演化而来的。SQL Server的未来版本是否支持它们现在还不能确定。微软推荐用户使用CHECK CONSTRAINT命令。然而,CHECK CONSTRAINTS不支持模块化编码。你必须为所有需要CHECK CONSTRAINT的表格的每一列都创建一个CHECK CONSTRAINT。另一方面,创建规则和缺省值,并把它们限制在一个用户自定义数据类型这个过程只需进行一次。用户自定义数据类型有很多种,比如性别和标签的布尔值。性别的域值可以是雄性,雌性,以及未知。布尔值的域值可以是数值,也可以是真假值。

下面的例子说明了向后兼容方法的模块性和关联域的未来方法。

EXEC sp_addtype @typename= TrueFalse, @phystype = 'CHAR(1)' ,_ @nulltype = 'NOT NULL', @owner = 'dbo'-- BACKWARD COMPATIBLE METHODCREATE RULE TrueFalseRuleAS @TrueFalse IN ('T','F') EXEC sp_bindrule TrueFalseRule, TrueFalseCREATE DEFAULT TrueFalseDefault AS 'F'EXEC sp_bindefault TrueFalseDefault, TrueFalse CREATE TABLE backward_test1(bt1_key1 INT IDENTITY NOT NULL,bt1_col1_flag TrueFalse)CREATE TABLE backward_test2(bt1_key2 INT IDENTITY NOT NULL,bt1_col2_flag TrueFalse)-- FUTURE METHODCREATE TABLE future_test1(ft1_key1 INT IDENTITY NOT NULL,ft1_col1_flag CHAR(1)CONSTRAINT ck_ft1_flag1 CHECK ( ft1_col1_flag in ('T','F') )DEFAULT 'F')CREATE TABLE future_test2(ft2_key1 INT IDENTITY NOT NULL,ft2_col1_flag CHAR(1)CONSTRAINT ck_ft2_flag1 CHECK ( ft2_col1_flag in ('T','F') )DEFAULT 'F')