warldge 2023-03-24 10:39 采纳率: 52.6%
浏览 24
已结题

SQL中的字段如何设置为存在性互斥?

SQL中的字段如何设置为存在性互斥?

字段A如果是非空, 那么字段B就必须是空的, 反之字段B如果有值, 则字段A就要是空的, 请问怎么给表加这种互斥约束?

  • 写回答

2条回答 默认 最新

  • 海洋 之心 2022年度博客之星人工智能领域TOP 1 2023-03-24 10:46
    关注

    你可以尝试 SQL 中的 CHECK 约束来实现字段存在性互斥。

    这段代码博主试一下:

    CREATE TABLE my_table (
      field_a VARCHAR(255),
      field_b VARCHAR(255),
      CHECK ((field_a IS NULL AND field_b IS NOT NULL) OR (field_a IS NOT NULL AND field_b IS NULL))
    );
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月2日
  • 已采纳回答 3月25日
  • 创建了问题 3月24日