微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决基于连接数据的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 吗?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。