我正在使用 Oracle 10g,我想对表应用约束,其中为一列输入的值确定另一列是 NULL 还是 IS NOT NULL。 Column1只能包含1或0; Column2 是 VARCHAR2(255)。
我知道以下方法有效:
CONSTRAINT ck_1 CHECK ((col1=1 AND col2 IS NOT NULL) OR (col1=0 AND col2 IS NULL));
但是,我想知道是否可以使用 CASE 来执行此约束并在 col2 上设置属性 NOT NULL,或者 CASE 只能用于定义值吗?即可以像这样工作:
CONSTRAINT ck_1 CHECK (CASE WHEN col1=1 THEN col2 IS NOT NULL ELSE col2 IS NULL END);
由于 CASE 表达式必须返回一个值,并且检查约束是布尔值,因此您必须将结果与某些内容进行比较,例如:
CONSTRAINT ck_1 CHECK (CASE WHEN col2 IS NOT NULL THEN 1 ELSE 0 END = col1);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)