| 假如由两个列共同组成主键,而且一个子表将主键作为可为空值的外键来继续,就可能得到错误的数据。可在一个外键列中插入有效的值,但在另一个外键列中插入空值。然后,可添加一个数据表检查约束,在可为空的外键中检查数据的有效性。 任何多列外键都可能碰到同样的问题。所以,你需要添加一个检查约束来检测异常。最初,检查约束将检查构成外键的所有列中可能为空的值。检查约束还要检查这些列中不能为空的值。如两个检查都通过,问题就解决了。 以下示范脚本展示了这样的一个异常,以及如何用检查约束来纠正它。
SET NOCOUNT ON GO CREATE TABLE parent (pkey1 INT IDENTITY NOT NULL, pkey2 INT
NOT NULL, col1 INT NULL, CONSTRAINT pk_parent PRIMARY KEY NONCLUSTERED ( pkey1, pkey2)) GO INSERT parent (pkey2) VALUES ( 2 ) INSERT parent (pkey2) VALUES ( 85 ) INSERT parent (pkey2) VALUES ( 41 ) INSERT parent (pkey2) VALUES ( 11 ) GO SELECT * FROM parent GO CREATE TABLE child (cpkey1 INT IDENTITY NOT NULL CONSTRAINT pk_child PRIMARY KEY NONCLUSTERED (cpkey1), pkey1 INT NULL, pkey2 INT NULL, col1 INT NULL, CONSTRAINT fk_parent_child FOREIGN KEY (pkey1, pkey2) REFERENCES parent (pkey1, pkey2)) GO INSERT child (pkey1, pkey2) VALUES ( null, 85 ) GO SELECT * FROM child GO DELETE child GO ALTER TABLE child WITH NOCHECK ADD CONSTRAINT ck_fk_parent_child CHECK ((pkey1 IS NOT NULL AND pkey2 IS NOT NULL) OR (pkey1 IS NULL AND pkey2 IS NULL) ) GO INSERT child (pkey1, pkey2) VALUES ( null, 11 ) GO DROP TABLE child, parent GO
空值是所有数据库开发者和治理员都要碰到的。所以,要想开发成功的应用程序,必须知道如何处理这些值。本文和你分享了空值处理的一些技巧和技术。
|
| 共2页: 上一页 [1] 2 下一页 |
评论加载中…