草庐IT

mysql - SELECT Duplicate/Repeating values with count N 没有 COUNT 或 GROUP BY

coder 2023-10-17 原文

假设我有一张人员 ID(1-8) 和人员角色(1-4) 的表:

CREATE TABLE personRole (
PersonId int NOT NULL,
RoleId int NOT NULL
);

INSERT INTO personRole
VALUES
(1, 1),
(1, 2),
(2, 1),
(2, 3),
(3, 3),
(4, 3),
(1, 4),
(5, 2),
(6, 1),
(7, 1),
(7, 4),
(8, 1),
(8, 2),
(8, 4)
;

我的目标是选择具有 3 个或更多角色的人员 ID,角色具体为 1、2 和 4。这是我的第一个解决方案:

SELECT PersonId FROM personRole
WHERE RoleID in (1,2,4)
GROUP BY PersonId
HAVING count(*) >= 3

但后来我被告知不要使用 GROUP BY,因为它很慢,所以我想出了这个解决方案:

SELECT distinct PersonId
FROM 
(
  SELECT PersonId, count(*) over(partition by PersonId) AS pcount
  FROM (SELECT * FROM personRole WHERE RoleID in (1,2,4)) AS A
) AS S
WHERE pcount >= 3

我将这些包括在内是为了举例说明我正在努力实现的目标。 但现在我被告知要不计其数地尝试它。我目前能够找到所有具有重复/重复人员 ID 的行:

 SELECT personId
 FROM personRole AS a
 WHERE EXISTS (
   SELECT 1
   FROM   personRole AS a2
   WHERE  a2.PersonId = a.PersonId
   AND    a2.RoleID <> a.RoleID
 );

但我一直在尝试找出如何仅在它们重复 3 次或更多次时才选择它们。如果可以的话,我想我可以将它与以下内容相交:

SELECT PersonId FROM personRole
WHERE RoleID in (1,2,4)

获得我的完整解决方案。到目前为止,我是正确地解决了这个问题,还是走错了方向?

最佳答案

独裁者所说的“没有计数”是指没有聚合函数吗?你总是可以用 sum(1) 而不是 count(*)。

否则,尝试自连接。

select a.PersonId, 
   a.RoleId, 
   b.RoleId, 
   c.RoleId,
   d.RoleId
from personRole a
    left join personRole b
    on a.PersonId = b.PersonId
    and a.RoleId <> b.RoleId
left join personRole c
    on a.PersonId = c.PersonId
    and a.RoleId <> c.RoleId
    and b.RoleId <> c.RoleId
left join personRole d
    on a.PersonId = d.PersonId
    and a.RoleId <> d.RoleId
    and b.RoleId <> d.RoleId
    and c.RoleId <> d.RoleId
order by a.PersonId, a.RoleId
;

+----------+--------+--------+--------+--------+
| PersonId | RoleId | RoleId | RoleId | RoleId |
+----------+--------+--------+--------+--------+
|        1 |      1 |      4 |      2 |   NULL |
|        1 |      1 |      2 |      4 |   NULL |
|        1 |      2 |      4 |      1 |   NULL |
|        1 |      2 |      1 |      4 |   NULL |
|        1 |      4 |      2 |      1 |   NULL |
|        1 |      4 |      1 |      2 |   NULL |
|        2 |      1 |      3 |   NULL |   NULL |
|        2 |      3 |      1 |   NULL |   NULL |
|        3 |      3 |   NULL |   NULL |   NULL |
|        4 |      3 |   NULL |   NULL |   NULL |
|        5 |      2 |   NULL |   NULL |   NULL |
|        6 |      1 |   NULL |   NULL |   NULL |
|        7 |      1 |      4 |   NULL |   NULL |
|        7 |      4 |      1 |   NULL |   NULL |
|        8 |      1 |      2 |      4 |   NULL |
|        8 |      1 |      4 |      2 |   NULL |
|        8 |      2 |      1 |      4 |   NULL |
|        8 |      2 |      4 |      1 |   NULL |
|        8 |      4 |      2 |      1 |   NULL |
|        8 |      4 |      1 |      2 |   NULL |
+----------+--------+--------+--------+--------+
20 rows in set (0.00 sec)

使用在 c.RoleId 中查找值的 where 子句限制它 - 并使用您的魔数(Magic Number)来剔除笛卡尔积,如下所示:

select a.PersonId, 
       a.RoleId, 
       b.RoleId, 
       c.RoleId
from personRole a
left join personRole b
    on a.PersonId = b.PersonId
left join personRole c
    on a.PersonId = c.PersonId
where 
    b.RoleId <> a.RoleId
    and b.RoleId <> c.RoleId
    and c.RoleId <> a.RoleId
    and c.RoleId <> b.RoleId
    and a.RoleId = 1
    and b.RoleId = 2
    and c.RoleId = 4
order by a.PersonId, a.RoleId
;

+----------+--------+--------+--------+
| PersonId | RoleId | RoleId | RoleId |
+----------+--------+--------+--------+
|        1 |      1 |      2 |      4 |
|        8 |      1 |      2 |      4 |
+----------+--------+--------+--------+
2 rows in set (0.00 sec)

如果你想让它更紧凑,而且你只搜索这一种情况,你可以一起取消左连接和值比较

mysql> select a.PersonId, 
    ->        a.RoleId, 
    ->        b.RoleId, 
    ->        c.RoleId
    -> from personRole a,
    ->      personRole b,
    ->      personRole c
    -> where 
    ->     a.PersonId = b.PersonId
    ->     and a.PersonId = c.PersonId
    ->     and a.RoleId = 1
    ->     and b.RoleId = 2
    ->     and c.RoleId = 4
    -> order by a.PersonId, a.RoleId
    -> ;
+----------+--------+--------+--------+
| PersonId | RoleId | RoleId | RoleId |
+----------+--------+--------+--------+
|        1 |      1 |      2 |      4 |
|        8 |      1 |      2 |      4 |
+----------+--------+--------+--------+
2 rows in set (0.00 sec)

关于mysql - SELECT Duplicate/Repeating values with count N 没有 COUNT 或 GROUP BY,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43619656/

有关mysql - SELECT Duplicate/Repeating values with count N 没有 COUNT 或 GROUP BY的更多相关文章

  1. ruby - 难道Lua没有和Ruby的method_missing相媲美的东西吗? - 2

    我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/

  2. ruby-on-rails - rails 目前在重启后没有安装 - 2

    我有一个奇怪的问题:我在rvm上安装了ruby​​onrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(

  3. ruby - 在没有 sass 引擎的情况下使用 sass 颜色函数 - 2

    我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re

  4. 没有类的 Ruby 方法? - 2

    大家好!我想知道Ruby中未使用语法ClassName.method_name调用的方法是如何工作的。我头脑中的一些是puts、print、gets、chomp。可以在不使用点运算符的情况下调用这些方法。为什么是这样?他们来自哪里?我怎样才能看到这些方法的完整列表? 最佳答案 Kernel中的所有方法都可用于Object类的所有对象或从Object派生的任何类。您可以使用Kernel.instance_methods列出它们。 关于没有类的Ruby方法?,我们在StackOverflow

  5. ruby-on-rails - Rails 3,嵌套资源,没有路由匹配 [PUT] - 2

    我真的为这个而疯狂。我一直在搜索答案并尝试我找到的所有内容,包括相关问题和stackoverflow上的答案,但仍然无法正常工作。我正在使用嵌套资源,但无法使表单正常工作。我总是遇到错误,例如没有路线匹配[PUT]"/galleries/1/photos"表格在这里:/galleries/1/photos/1/edit路线.rbresources:galleriesdoresources:photosendresources:galleriesresources:photos照片Controller.rbdefnew@gallery=Gallery.find(params[:galle

  6. ruby-on-rails - 有没有办法为 CarrierWave/Fog 设置上传进度指示器? - 2

    我在Rails应用程序中使用CarrierWave/Fog将视频上传到AmazonS3。有没有办法判断上传的进度,让我可以显示上传进度如何? 最佳答案 CarrierWave和Fog本身没有这种功能;你需要一个前端uploader来显示进度。当我不得不解决这个问题时,我使用了jQueryfileupload因为我的堆栈中已经有jQuery。甚至还有apostonCarrierWaveintegration因此您只需按照那里的说明操作即可获得适用于您的应用的进度条。 关于ruby-on-r

  7. ruby - 没有类方法获取 Ruby 类名 - 2

    如何在Ruby中获取BasicObject实例的类名?例如,假设我有这个:classMyObjectSystem我怎样才能使这段代码成功?编辑:我发现Object的实例方法class被定义为returnrb_class_real(CLASS_OF(obj));。有什么方法可以从Ruby中使用它? 最佳答案 我花了一些时间研究irb并想出了这个:classBasicObjectdefclassklass=class这将为任何从BasicObject继承的对象提供一个#class您可以调用的方法。编辑评论中要求的进一步解释:假设你有对象

  8. 使用canal同步MySQL数据到ES - 2

    文章目录一、概述简介原理模块二、配置Mysql使用版本环境要求1.操作系统2.mysql要求三、配置canal-server离线下载在线下载上传解压修改配置单机配置集群配置分库分表配置1.修改全局配置2.实例配置垂直分库水平分库3.修改group-instance.xml4.启动监听四、配置canal-adapter1修改启动配置2配置映射文件3启动ES数据同步查询所有订阅同步数据同步开关启动4.验证五、配置canal-admin一、概述简介canal是Alibaba旗下的一款开源项目,Java开发。基于数据库增量日志解析,提供增量数据订阅&消费。Git地址:https://github.co

  9. ruby - 没有轨道的 ActiveRecord 时区 - 2

    我在非Rails项目中使用ActiveRecord。在Rails中,我可以这样做:config.time_zone='EasternTime(US&Canada)'config.active_record.default_timezone='EasternTime(US&Canada)'但如果我不使用rails,我该如何设置时区? 最佳答案 ActiveRecord::Base.default_timezone='EasternTime(US&Canada)' 关于ruby-没有轨道的A

  10. ruby-on-rails - 没有这样的文件或目录 - 用 Mini Magick 识别 - 2

    在我让另一个人重做我的前端UI之前,我的Rails应用程序运行平稳。我已经尝试解决此错误3天了。这是错误:Nosuchfileordirectory-identifyExtractedsource(aroundline#59):575859606162@post=Post.find(params[:id])authorize@postif@post.update_attributes(post_params)flash[:notice]="Postwasupdated."redirect_to[@topic,@post]else{"utf8"=>"✓","_method"=>"patc

随机推荐