基于连接数据的mysql唯一索引

问题描述

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

用户: id,company_id

保险箱: id、user_id、location_id

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

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

解决方法

你的意思是这样吗

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 吗?