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

MSSQL
SQL Server SA权限总结经典技术
ASP数据库编程SQL常用技巧
SQL SERVER数据库开发之存储过程应用
SQL Server 2000的安全配置
MSSQL经典语句
SQL 经典语句
有用的SQL语句(删除重复记录,收缩日志)
Access 数据类型与 MS SQL 数据类型的相应
SQL语句示例
SQL数据类型详解
将Sql Server对象的当前拥有者更改成目标拥有者
MSSQL内外连接(INNER JOIN)语句详解
SQL 外链接操作小结 inner join left join right join
SQL Server中网络备份一例
SQL语句导入导出大全
SQL 新增/修改 表字段列的类型等
系统存储过程,sp_executesql
sql2005开启xp_cmdshell
实例学习SQL的Select命令
删除数据库中重复数据的几个方法

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 63 ::
收藏到网摘: 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')