首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >更改表检查约束

更改表检查约束
EN

Stack Overflow用户
提问于 2013-05-27 00:51:52
回答 1查看 9K关注 0票数 3

从命令的第35行开始出错:

代码语言:javascript
运行
复制
ALTER TABLE lee_person
  ADD CONSTRAINT check_person_type 
  CHECK(CASE WHEN UPPER(person_type) = 'EMPLOYEE'
             THEN employment_date IS NOT NULL 
             AND  manager_id IS NOT NULL
             WHEN UPPER(person_type) = 'CLIENT'
             THEN employment_date IS NULL 
             AND  manager_id IS NULL                
        END)

错误报告:

代码语言:javascript
运行
复制
SQL Error: ORA-00905: missing keyword
00905. 00000 -  "missing keyword"
*Cause:    
*Action:
EN

回答 1

Stack Overflow用户

发布于 2013-05-27 01:18:42

您不能像您正在尝试的那样使用CASE (CASE WHEN condition-A THEN condition-B AND condition-C)。

看起来,您希望强制执行以下操作:

  1. 如果person_typeemployee (不区分大小写),则employment_datemanager_id必须是NOT NULL
  2. 如果person_typeclient (不区分大小写),则employment_datemanager_id必须是NULL

如果是这样的话,试一试吧:

代码语言:javascript
运行
复制
ALTER TABLE lee_person
  ADD CONSTRAINT check_person_type
  CHECK ( (UPPER(person_type) = 'EMPLOYEE' AND
           employment_date IS NOT NULL AND
           manager_id IS NOT NULL)
       OR (UPPER(person_type) = 'CLIENT' AND
           employment_date IS NULL AND
           manager_id IS NULL)
  )

我已经测试过了,效果很好。

请注意,它允许的唯一person_type值是employeeclient (不区分大小写)。如果您希望允许其他类型(无论是否有employment_datemanager_id限制),则需要调整其他OR条件。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16765087

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档