【问题标题】:mysql unique index based on joined data基于连接数据的mysql唯一索引
【发布时间】:2021-02-02 21:10:52
【问题描述】:

我有一个用户和一个保险箱表

用户: id, company_id

保险箱: id、user_id、location_id

我想确保 location_id 在 company_id 中是唯一的。有没有办法通过 user_id 做到这一点,还是我必须将 company_id 添加到 safes_table?

即是否有某种可以解释连接的唯一索引?我也愿意接受任何其他基于数据库的解决方案。

【问题讨论】:

    标签: mysql unique-index


    【解决方案1】:

    你的意思是这样的

    SELECT company_id
    FROM
    (SELECT company_id, COUNT(*) count
    FROM
    (SELECT DISTINCT company_id, location_id
    FROM safes
    LEFT JOIN users
    ON users.id = safes.user_id) comp_loc_pair
    GROUP BY company_id) loc_count_by_comp
    WHERE count > 1
    

    其中列出了拥有多个地点的公司,这个

    SELECT cle, TypeContact
    FROM
    (SELECT cle, TypeContact, COUNT(*) count
    FROM
    (SELECT cle, TypeContact 
    FROM img_images 
    LEFT JOIN consu_lien 
    ON consu_lien.NumRelation = img_images.Cle) comp_loc_pair
    GROUP BY cle, TypeContact) comp_loc_counts
    WHERE count > 1
    

    其中显示了多次配对的公司和位置,或者您要检查特定的 location_id 和 company_id 吗?

    【讨论】:

      猜你喜欢
      • 2023-03-08
      • 2023-02-21
      • 2016-04-27
      • 1970-01-01
      • 2020-10-21
      • 2023-03-09
      • 2011-10-05
      • 2014-08-01
      • 2021-04-21
      相关资源
      最近更新 更多