假如在 CREATE INDEX 语句中指定了 IGNORE_DUP_KEY,并执行了产生重复键的 INSERT 或 UPDATE 语句,SQL Server 就会发出一条警告消息,并忽略(不插入)此重复的行。假如没有给索引指定 IGNORE_DUP_KEY,SQL Server 就会发出一个错误信息,并回滚整个 INSERT 语句。有关这些选项的具体信息,请参见 SQL Server Books Online。
对于每个字符使用 1 个字节编码的数据类型来说,一个问题是这种数据类型只能表示 256 个不同的字符。这就要求对于不同的字母表,必须采用多个编码规范(或代码页)。它也不能处理像日语 Kanji 或韩国语 Hangul 字母表这样有几千个字符的系统。
Microsoft SQL Server 使用与 SQL Server 一起安装的代码页中的定义,将 char、varchar 和 text 列中的位模式转换成字符。客户计算机使用与操作系统一起安装的代码页解释位模式。 有许多种不同的代码页。有些字符在一些代码页中,但不在其它代码页中。有些字符在一些代码页中用一种位模式定义,在其它代码页中则使用另一种位模式。当创建必须处理各种语言的国际化系统时,要为所有计算机挑选满足多个国家语言要求的代码页,就变得十分困难。而且也很难保证,所有计算机与使用不同代码页的系统交互时,能够进行正确转换。
在 SQL Server 中,nchar、nvarchar 和 ntext 数据类型均支持 Unicode 数据。有关 SQL Server 数据类型的具体信息,请参见 SQL Server Books Online。
用户定义的数据类型。 可为 model 数据库或单个用户数据库创建用户定义的数据类型。假如用户定义的数据类型是为 model 定义的,此后创建的所有新用户数据库均可使用该数据类型。用户定义的数据类型是用 sp_addtype 系统存储过程定义的。有关具体信息,请参见 SQL Server Books Online。
可以在 CREATE TABLE 和 ALTER TABLE 语句中使用用户定义的数据类型,并将其与默认值和规则绑定在一起。表创建过程中,假如使用用户定义的数据类型时,明确地定义了为空性,则它优先于数据类型创建时定义的为空性。
此例给出了,如何创建一个用户定义的数据类型。参数为用户类型名称、数据类型和为空性。
sp_addtype gender_type, 'varchar(1)', 'not null' go
乍看起来,此功能解决了 Oracle 表创建脚本向 SQL Server 迁移的问题。比如,可以方便地增添 Oracle DATE 数据类型:
约束的命名 应该始终显式命名约束。假如没有,则 Oracle 和 Microsoft SQL Server 使用不同的命名规则隐式命名约束。这些命名上的差别会给迁移过程带来不必要的麻烦。在删除或禁用约束时,就会造成不一致,因为必须使用名称,约束才能被删除。对于 Oracle 和 SQL Server 来说,显式命名约束的语法是相同的。