- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了与 MySQL 中的组函数无效使用
相关的问题。
我尝试执行的查询是这样的(我知道这是一个非常大的查询,但如果我可以执行它,那么我将调整和修复性能和易于阅读的内容):
SELECT
`id_c` AS `sceneId`,
`scene`.`id` AS `sceneName`,
`scene`.`frameCount` AS `frames`,
task.id_mv AS `id_mv`,
CONCAT( '[',GROUP_CONCAT(
CONCAT(
'{',
'"idTk": ', `task`.`id_tk`, ', ',
-- '"tktype": ', `task`.`id_tk_type`, ', ',
-- '"subDepType": ', IF ( `task`.`id_sub_dep_type` = 54, `task`.`id_sub_dep_type`, 'null'), ', ',
-- '"color": "', `task`.`color`, '", ',
'"weight": ', MAX(`task`.`weight`), ', ',
'"dept": ', '"',
CASE `task`.`id_tk_type`
WHEN 43 THEN 'MVB'
WHEN 12 THEN 'LYT'
WHEN 32 THEN
CONCAT_WS(
', ',
IF( `task`.`id_sub_dep_type` != 54, 'ANI', NULL ),
IF( `task`.`id_sub_dep_type` = 54, 'CKD', NULL )
)
WHEN 190 THEN 'DYN'
WHEN 104 THEN 'FIN'
WHEN 191 THEN 'LGT'
END, '"',
-- task.id_tk_type, ', ',
-- task.id_sub_dep_type,
'}'
)
ORDER BY
FIELD( `task`.`id_tk_type`, 43, 12, 32, 190, 104, 191 ),
`task`.`weight` DESC
SEPARATOR
', '
), ']') AS `tkInfo`
FROM
`V_task` AS `task`
JOIN `tk_fct_mcsc` AS `mcsc` ON `task`.`id_tk` = `mcsc`.`id_tk`
JOIN `scene` ON `mcsc`.`id_c` = `scene`.`id_scene`
WHERE
`task`.`id_sub_dep_type` IN (
SELECT
`id_sub_dep_type`
FROM
`tk_dim_sub_dep_type`
WHERE `id_tk_type` IN (
SELECT
`id_tk_type`
FROM
`tk_dim_dep_type`
WHERE
`id_tk_type` IN ( 43, 12, 32, 190, 104, 191 )
)
AND `id_sub_dep_type` != 54
UNION
SELECT
`id_sub_dep_type`
FROM
`tk_dim_sub_dep_type`
WHERE
`id_sub_dep_type` = 54
)
AND `task`.`is_appr` = FALSE
AND `mcsc`.`type` = 'sc'
AND `scene`.`id` != '000'
-- AND `mcsc`.`id_b` = 530
GROUP BY
`scene`.`id`,
`scene`.`id_scene`
-- task.weight
ORDER BY
`scene`.`id`,
`task`.`weight` DESC;
错误,我知道是GROUP_CONCAT
函数内的MAX(task.weight)
,但我不知道如何避免这个事情..
我实际上正在尝试构建某种 sqlfiddle 的东西来让你测试这些东西,但我认为我需要的只是另一双眼睛,让我知道在哪里看。
谢谢!
编辑#1如kickstart问,我想要获得的是这样的东西:
sceneId sceneName frames id_mv tkInfo
200 001 1200 1 "[{"dept": "LGT"}, {"dept": "LGT"}]"
1342 001 45 14 "[{"dept": "LYT"}, {"dept": "LGT"}, {"dept": "LGT"}]"
1335 001 460 14 "[{"dept": "MVB"}, {"dept": "LYT"}, {"dept": "LGT"}, {"dept": "LGT"}]"
1351 001 20 11 "[{"dept": "LYT"}, {"dept": "ANI"}, {"dept": "FIN"}, {"dept": "LGT"}]"
1375 001 63 11 "[{"dept": "LYT"}, {"dept": "CKD"}, {"dept": "ANI"}, {"dept": "DYN"}, {"dept": "FIN"}, {"dept": "FIN"}, {"dept": "FIN"}, {"dept": "LGT"}]"
1382 001 66 11 "[{"dept": "LYT"}, {"dept": "CKD"}, {"dept": "ANI"}, {"dept": "FIN"}]"
但是,如果没有重复“部门”,那么我需要该部门的最大权重。
编辑#2我用一点小作弊解决了我的这个问题。
首先,我简化了主查询,删除了 case-thing 并为每个 sceneId 插入了 MAX(权重)。
通过这个简化的查询,我构建了一个 View ,并通过该 View 应用了 case/group_concat 事物..并且所有结果都很好。
[ ..sqlfiddle 将立即插入此处.. ]
最佳答案
有一点尝试,并且(非常)未经测试,但认为您需要有效地执行两次查询。一次获取详细信息,一次获取最大重量。您可以移动一些子选择(进行连接 - 联合将在连接之前处理重复项)。
类似这样的:-
SELECT
Sub1.id_c AS sceneId,
Sub1.id AS sceneName,
Sub1.frameCount AS frames,
Sub1.id_mv AS id_mv,
CONCAT( '[',GROUP_CONCAT(
CONCAT(
'{',
'"idTk": ', Sub1.id_tk, ', ',
'"weight": ', Sub2.MaxTaskWeight, ', ',
'"dept": ', '"', Sub1.id_tk_type_decode, '"',
'}'
)
ORDER BY
FIELD( Sub1.id_tk_type, 43, 12, 32, 190, 104, 191 ),
Sub2.MaxTaskWeight DESC
SEPARATOR
', '
), ']') AS tkInfo
FROM
(
SELECT
id_c AS sceneId,
scene.id AS sceneName,
scene.frameCount AS frames,
task.id_mv AS id_mv,
task.id_tk,
CASE task.id_tk_type
WHEN 43 THEN 'MVB'
WHEN 12 THEN 'LYT'
WHEN 32 THEN IF( task.id_sub_dep_type = 54, 'CKD', 'ANI' )
WHEN 190 THEN 'DYN'
WHEN 104 THEN 'FIN'
WHEN 191 THEN 'LGT'
END AS id_tk_type_decode,
task.id_tk_type
FROM V_task AS task
INNER JOIN tk_fct_mcsc AS mcsc ON task.id_tk = mcsc.id_tk
INNER JOIN scene ON mcsc.id_c = scene.id_scene
INNER JOIN
(
SELECT id_sub_dep_type
FROM tk_dim_sub_dep_type
INNER JOIN tk_dim_dep_type
ON tk_dim_sub_dep_type.id_tk_type = tk_dim_dep_type.id_tk_type
WHERE tk_dim_dep_type.id_tk_type IN ( 43, 12, 32, 190, 104, 191 )
AND tk_dim_sub_dep_type.id_sub_dep_type != 54
UNION
SELECT id_sub_dep_type
FROM tk_dim_sub_dep_type
WHERE id_sub_dep_type = 54
) Sub1
ON task.id_sub_dep_type = Sub1.id_sub_dep_type
WHERE task.is_appr = FALSE
AND mcsc.`type` = 'sc'
AND scene.`id` != '000'
)
INNER JOIN
(
SELECT scene.id, scene.id_scene, MAX(task.weight) AS MaxTaskWeight
FROM V_task AS task
INNER JOIN tk_fct_mcsc AS mcsc ON task.id_tk = mcsc.id_tk
INNER JOIN scene ON mcsc.id_c = scene.id_scene
INNER JOIN
(
SELECT id_sub_dep_type
FROM tk_dim_sub_dep_type
INNER JOIN tk_dim_dep_type
ON tk_dim_sub_dep_type.id_tk_type = tk_dim_dep_type.id_tk_type
WHERE tk_dim_dep_type.id_tk_type IN ( 43, 12, 32, 190, 104, 191 )
AND tk_dim_sub_dep_type.id_sub_dep_type != 54
UNION
SELECT id_sub_dep_type
FROM tk_dim_sub_dep_type
WHERE id_sub_dep_type = 54
) Sub1
ON task.id_sub_dep_type = Sub1.id_sub_dep_type
WHERE task.is_appr = FALSE
AND mcsc.`type` = 'sc'
AND scene.`id` != '000'
GROUP BY scene.id, scene.id_scene
) Sub2
ON Sub1.id = Sub2.id
AND Sub1.id_scene = Sub2.id_scene
GROUP BY
Sub1.id,
Sub1.id_scene
ORDER BY
Sub1.id,
MaxTaskWeight DESC;
关于mysql - 在 GROUP_CONCAT 中使用 MAX,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19811839/
快速且可能简单的 Lambda 问题: 我有一家有评论的餐厅。我想查询具有以下内容的那个: 最大(平均评分) 和 Max(ReviewCount) 和 Max(NewestReviewDate) 和
在尝试使用 C++17 折叠表达式时,我尝试实现 max sizeof ,其中结果是类型 sizeof 的最大值。我有一个使用变量和 lambda 的丑陋折叠版本,但我想不出一种使用折叠表达式和 st
我目前正在使用 C 并遇到了一些我觉得有趣的东西,但似乎在这里找不到任何类似的东西。 我正在为数组(大小 1000000)静态分配内存。我知道这相当大并且有可能引起问题。但是,使用 10^6 不会出现
我有一个具有 max-height 的 div 和其中的图像,应该使用 max-width:100% 和 max-height:100%。在 Chromium 中,这是可行的,但 Firefox 仅使
我有一个最大高度的 div 和里面的一个图像,它应该使用最大宽度:100% 和最大高度:100%。在 Chromium 中,这是可行的,但 Firefox 仅使用最大宽度而忽略最大高度。 div#ov
在一本在线 awk 手册中我找到了例子awk '{ if (NF > max) max = NF } END { print max }' 该程序打印任何输入行上的最大字段数。但我不明白 awk 如何
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在制作一个非循环图数据库。 表 Material (id_item,id_collection,...)主键(id_item,id_collection) (item可以是collection本身
我有以下两个表。 1.电影详情(电影ID、电影名称、评分、票数、年份) 2.电影类型(Movie-ID,Genre) 我正在使用以下查询来执行连接并获得每个评分最高的电影流派。 select Movi
我有一个查询,我想返回 idevent 中给定传感器 ID (sensorID) 范围内的最高 ID 值,但是查询没有返回最高值。 我运行查询时减去 max() 语句的结果: mysql> SELEC
SUM(MAX() + MAX()) 有正确的方法吗? 这是我一直在努力做的事情 SELECT SUM(MAX(account.BALANCE1) + MAX(account.BALANCE2))
这个问题类似于CSS media queries: max-width OR max-height , 但由于我的代表不够高,我无法在回复中添加评论(问题),我想在原始问题中添加。 与其他主题中的发帖
Jon Skeet今天报告(source): Math.Max(1f, float.NaN) == NaN new[] { 1f, float.NaN }.Max() == 1f 为什么? 编辑:双倍
这个问题已经有答案了: Java 8 stream's .min() and .max(): why does this compile? (5 个回答) 已关闭 7 年前。 我正在学习1z0-809
我在处理一些数据库记录时遇到了一些挑战。 我需要为特定列获取具有 MAX 值的行,并且这些记录必须介于两个时间戳值之间。 这是SQL查询 SELECT id, MAX(amount), created
我想在媒体查询中使用 AND 条件。我使用了下面的代码,但是没有用 @media screen and (max-width: 995px AND max-height: 700px) { } 最佳答
在编写 CSS 媒体查询时,有什么方法可以用“或”逻辑指定多个条件吗? 我正在尝试做这样的事情: /* This doesn't work */ @media screen and (max-widt
我对仅使用 max(list array) 和 np.max(list array) 之间的区别有疑问。 这里唯一的区别是 Python 返回代码所需的时间吗? 最佳答案 它们在边缘情况下可能不同,例
例如: a = [[0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0], [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.
这个问题在这里已经有了答案: Java 8 stream's .min() and .max(): why does this compile? (5 个答案) 关闭 6 年前。 我正在学习 1z0
我是一名优秀的程序员,十分优秀!