问题描述
用户: 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 吗?