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

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日

悬赏问题

  • ¥15 想问一下树莓派接上显示屏后出现如图所示画面,是什么问题导致的
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号