我正在尝试计算在我的数据库中找到的品牌总数
我有3张 table
车辆品牌
+----+------+
| id | make |
+----+------+
| 1 | Audi |
| 2 | BMW |
+----+------+
车辆广告
+----+-----------+----------+------+-----------+
| id | make_code | model | year | dealer_id |
+----+-----------+----------+------+-----------+
| 1 | 2 | 5 series | 2010 | 0 |
+----+-----------+----------+------+-----------+
| 2 | 2 | 3 series | 2014 | 20 |
+----+-----------+----------+------+-----------+
经销商
+----+------------+------+
| id | dealername | make |
+----+------------+------+
| 20 | bla bla | 2 |
+----+------------+------+
这是我的 sql 查询,我尝试将其 modify this所以我可以按品牌和 dealer_id 分组
SELECT j.make AS make, j.id AS id, sum(j.count) AS count FROM
(
(
SELECT v.make, sum(count+dealerCount)
FROM
( SELECT a.dealer_id, v.make AS make, a.make_code, COUNT(*) AS count
FROM `vehicle_make` AS v
JOIN `vehicle_ads` AS a
ON (v.id=a.make_code)
WHERE a.dealer_id>0
GROUP BY a.dealer_id, a.make_code
) AS g
JOIN
( SELECT a.dealer_id, v.make, a.make_code, COUNT(*) AS dealerCount
FROM `vehicle_make` AS v
JOIN `vehicle_ads` AS a
ON (v.id=a.make_code)
WHERE a.dealer_id>0
GROUP BY a.dealer_id
) AS gl
ON gl.dealer_id = g.dealer_id
JOIN
( SELECT a.make_code, COUNT(*) AS makeCount
FROM `vehicle_make` AS v
JOIN `vehicle_ads` AS a
ON (v.id=a.make_code)
WHERE a.dealer_id>0
GROUP BY a.make_code
) AS gg
ON gg.make_code=g.make_code
)
UNION
(
SELECT v.make AS make, v.id AS id, COUNT(*) AS count
FROM `dealership` AS d
JOIN `vehicle_make` AS v
ON (v.id=d.make)
GROUP BY d.make
)
) AS j GROUP BY j.make
现在我收到这个错误。
输出应该是这样的
+--------+----+-------+
| make | id | count |
+--------+----+-------+
| Audi | 1 | 300 |
| BMW | 2 | 150 |
| Toyota | 3 | 50 |
+--------+----+-------+
基本上它应该在 dealership 表中获取品牌总数,并在 vechile_ads 表中获取品牌总数(按品牌和 dealer_id 分组)
知道我在这里做错了什么。
更新: SQL FIDDLE
在上面的 fiddle 中,BMW 的 NUMADS 应该是 1(按 dealer_id 分组)并且返回的列应该是 make , make_code, count 其中 count 是 NUMADS + NUMDEALER
最佳答案
试试这个查询:
SELECT make.id,
make.make,
( IFNULL(ads.cout, 0) + IFNULL(deal.cout, 0) ) AS cout
FROM vehicle_make make
LEFT OUTER JOIN (SELECT make_code AS id,
Count(DISTINCT dealer_id) AS cout
FROM vehicle_ads
GROUP BY make_code) ads
ON make.id = ads.id
LEFT OUTER JOIN (SELECT make AS id,
Count(*) AS cout
FROM dealership
WHERE make IS NOT NULL
GROUP BY make) deal
ON make.id = deal.id;
子查询 ads 将为您提供 distinct dealers 的 count,他们为来自 的 表。子查询 make 发布了广告>vehicle_adsdeal 将为您提供 dealership 表中的制造数量。最后,使用 left outer join 将 vehicle_make 表连接到 ads 和 deal 以便结果应包含所有 id 和 make 并添加来自两个子查询的计数以获得所需的结果。
注意:在您的 sql fiddle 中,将 count(*) 替换为 count(distinct dealer_id) 将为您提供所需的内容。检查here .
关于Mysql按2个字段分组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26955453/
在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev
文章目录一、概述简介原理模块二、配置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
假设我有一个在Ruby中看起来像这样的哈希:{:ie0=>"Hi",:ex0=>"Hey",:eg0=>"Howdy",:ie1=>"Hello",:ex1=>"Greetings",:eg1=>"Goodday"}有什么好的方法可以将它变成如下内容:{"0"=>{"ie"=>"Hi","ex"=>"Hey","eg"=>"Howdy"},"1"=>{"ie"=>"Hello","ex"=>"Greetings","eg"=>"Goodday"}} 最佳答案 您要求一个好的方法来做到这一点,所以答案是:一种您或同事可以在六个月后理解
我看到其他人也遇到过类似的问题,但没有一个解决方案对我有用。0.3.14gem与其他gem文件一起存在。我已经完全按照此处指示完成了所有操作:https://github.com/brianmario/mysql2.我仍然得到以下信息。我不知道为什么安装程序指示它找不到include目录,因为我已经检查过它存在。thread.h文件存在,但不在ruby目录中。相反,它在这里:C:\RailsInstaller\DevKit\lib\perl5\5.8\msys\CORE\我正在运行Windows7并尝试在Aptana3中构建我的Rails项目。我的Ruby是1.9.3。$gemin
我已经开始使用mysql2gem。我试图弄清楚一些基本的事情——其中之一是如何明确地执行事务(对于批处理操作,比如多个INSERT/UPDATE查询)。在旧的ruby-mysql中,这是我的方法:client=Mysql.real_connect(...)inserts=["INSERTINTO...","UPDATE..WHEREid=..",#etc]client.autocommit(false)inserts.eachdo|ins|beginclient.query(ins)rescue#handleerrorsorabortentirelyendendclient.commi
我已经有很多两个值数组,例如下面的例子ary=[[1,2],[2,3],[1,3],[4,5],[5,6],[4,7],[7,8],[4,8]]我想把它们分组到[1,2,3],[4,5],[5,6],[4,7,8]因为意思是1和2有关系,2和3有关系,1和3有关系,所以1,2,3都有关系我如何通过ruby库或任何算法来做到这一点? 最佳答案 这是基本Bron–Kerboschalgorithm的Ruby实现:classGraphdefinitialize(edges)@edges=edgesenddeffind_maximum_
如果至少有两个相邻的数字相同,格式为,我需要打包.这是我的输入:[2,2,2,3,4,3,3,2,4,4,5]以及预期的输出:"2:3,3,4,3:2,2,4:2,5"到目前为止我试过:a=[1,1,1,2,2,3,2,3,4,4,5]a.each_cons(2).any?do|s,t|ifs==t如果相等,也许可以尝试计数器,但那是行不通的。 最佳答案 您可以使用Enumerable#chunk_while(如果你使用的是Ruby>=2.3):a.chunk_while{|a,b|a==b}.flat_map{|chunk|chu
我有一个文件,每一行都有数字:010110101311010113114311010431420我想要一个包含每个数字出现次数的散列,在这种情况下:{0101=>2,1010=>2,1311=>2,431=>2,420=>1}我该怎么做? 最佳答案 简单的一行代码,给定一个数组items:items.inject(Hash.new(0)){|hash,item|hash[item]+=1;hash}工作原理:Hash.new(0)创建一个新的Hash,其中访问未定义的键返回0。inject(foo)使用给定的block遍历数组。对于
我正在尝试绕过rails配置这个极其复杂的迷宫。到目前为止,我设法在ubuntu上设置了rvm(出于某种原因,ruby在ubuntu存储库中已经过时了)。我设法建立了一个Rails项目。我希望我的测试项目使用mysql而不是mysqlite。当我尝试“rakedb:migrate”时,出现错误:“!!!缺少mysql2gem。将其添加到您的Gemfile:gem'mysql2'”当我尝试“geminstallmysql”时,出现错误,告诉我需要为安装命令提供参数。但是,参数列表很大,我不知道该选择哪些。如何通过在ubuntu上运行的rvm和mysql获取rails3?谢谢。
对于按日期分组,我使用了group_by方法。Example:Product.all.group_by{|d|d.created_at}#returnHash但是kaminari不支持Hash。我使用Mongoid,我需要通过页面导航(kaminari)按日期分组。怎么做到的? 最佳答案 Kaminari只支持数组分页例如Kaminari.paginate_array(an_array).page(1).per(10)group_by不是mongoid方法,它是Array的方法,它是对内存中的所有数据进行分组。为了使用mongoid