如何使用CHECK约束为SQL Server数据执行域完整性

开发者在线 Builder.com.cn 更新时间:2007-03-19作者:builder.com.cn 来源:

我们在例子中使用的表包含两个nchar栏——ZIPCode和City栏。你可以使用任何SQL Server表,只要其中包含一个邮政编码栏即可。

  • 按照我们的例子,运行下列语句建立表:
    CREATE TABLE ZIPCodesZIPCodenchar(5), City nchar(30)
  • 在Management Studio的Object Explorer中,打开上面的表。
  • 右击Constraints(约束)并选择New Constraint(新约束)。
  • 在CHECK Constraints对话框的Expression(表达式)框中输入以下约束表达式,如A所示(仅显示一部分)。
    ZIPCode like '[0-9] [0-9] [0-9] [0-9] [0-9]'
  • 将约束命名为CK_ZIPCodes_ZIPCoce。
  • 输入一段简短的说明,如“限定邮政编码为五位数字”。
  • 点击Add(添加)然后Close(关闭)。
  • 在Standard(标准)菜单上点击Save(保存)。

图A

如何使用CHECK约束为SQL Server数据执行域完整性

CHECK约束使用一个表达式决定用户输入是否有效

你可以避开手动过程,执行一个下列格式的SQL语句(只要表已经存在):

ALTER TABLE tablename ADD CONSTRAINT constraintname CHECK (expression)

如果是上例中的表,则执行以下语句:

ALTER TABLE dbo.ZIPCodes ADD CONSTRAINT CK_ZIPCodes_ZIPCode CHECK (ZIPCode like '[0-9] [0-9] [0-9] [0-9] [0-9]')

[0-9]部分将指定位置的字符限定为0-9之间的任何数字。由于表达式重复使用了五个[0-9],表示这个约束只允许五个数字。大括号([])是你指定一组字符所用到的通配符。(欲了解约束表达式的更多信息,请查看在线手册。)

添加CHECK约束后,点击New Query(新查询)并执行以下SQL语句增加一个无效的邮政编码:

INSERT ZIPCodes (ZIPCode, City)

VALUES ('555aa', 'Smallville')

图B显示得到的结果。值555aa中包含两个违反[0-9]约束的字符。因此,SQL Server拒绝这个输入。不使用CHECK约束,SQL Server将接受555aa这个值。

图B

如何使用CHECK约束为SQL Server数据执行域完整性

CHECK约束不会接受555aa,因为其中包含alpha字符

记住,上面例子中的约束并不能保证它接受的输入确实是一个有效的邮政编码。它只能保证接受的值仅包含数字。

Susan Sales Harkins是一名独立顾问,也是数据库技术方面许多文章和书籍的作者。Mastering Microsoft SQL Server 2005 Express是她最近与Mike Gunderloy合著的作品,由Sybex出版。

她和Gunderloy合作的其它作品包括:Automating Microsoft Access 2003 with VBA、Upgrader's Guide to Microsoft Office System 2003、 ICDL Exam Cram 2和Absolute Beginner's Guide to Microsoft Access 2003,这些书籍全都由Que出版。当前,Susan是Database Advisors的义务发行总监。

责任编辑:德东

查看本文国际来源

用户评论

  • 用户名
  • 评论内容