跨行满足唯一条件的值选择
本问题描述了一种场景,其中我们有一个包含两列的表:userid 和 roleid。目标是检索拥有所有三个指定 roleid 的唯一 userid。
一种方法是结合聚合和过滤:
<code class="language-sql">SELECT userid FROM userrole WHERE roleid IN (1, 2, 3) GROUP BY userid HAVING COUNT(1) = 3</code>
此查询按 userid 分组结果,计算每个 userid 的每个 roleid 的出现次数。HAVING 子句确保只选择具有三个不同 roleid 的 userid。
然而,使用连接的另一种方法可能更高效,尤其是在处理大型数据集时:
<code class="language-sql">SELECT t1.userid FROM userrole t1 JOIN userrole t2 ON t1.userid = t2.userid AND t2.roleid = 2 JOIN userrole t3 ON t2.userid = t3.userid AND t3.roleid = 3 AND t1.roleid = 1</code>
此查询利用嵌套连接根据指定的 roleid 选择 userid。外部连接条件检查每个 userid 的每个 roleid 的存在,最终的 AND 条件确保所选 userid 具有所有三个指定的 roleid。
根据底层数据库系统的数据分布和性能特征,任一方法都可能更合适。建议测试这两种方法,以确定适合您特定场景的最佳解决方案。
以上是如何高效查找具有全部三个指定角色ID的用户?的详细内容。更多信息请关注PHP中文网其他相关文章!