gpt4 book ai didi

mysql排序: will it work consistantly?解决方案

转载 作者:可可西里 更新时间:2023-11-01 08:37:47 24 4
gpt4 key购买 nike

我有这个查询:

SELECT `name`, floor(max(score)), skill
FROM
(SELECT k.`name`, s.`name` as skill, *long complex formula* as score
FROM `keywords_skills` ks
JOIN keywords k ON k.id = ks.keyword_id
JOIN skills s ON s.id = ks.skill_id
JOIN jobs_keywords jk ON jk.keyword_id = k.id
WHERE job_id = 87293) t1
GROUP BY `name`
ORDER BY `name` asc

显然我希望“技能”与 max(score) 引用同一行,但我不知道如何实现。但是,当我像这样向子查询添加 ORDER BY 时:

SELECT `name`, floor(max(score)), skill
FROM
(SELECT k.`name`, s.`name` as skill, *long complex formula* as score
FROM `keywords_skills` ks
JOIN keywords k ON k.id = ks.keyword_id
JOIN skills s ON s.id = ks.skill_id
JOIN jobs_keywords jk ON jk.keyword_id = k.id
WHERE job_id = 87293
ORDER BY score DESC) t1
GROUP BY `name`
ORDER BY `name` asc

一切似乎都很好!我的问题是:我是否解决了我的问题,或者只是实现了一个不可靠的 hack,以后会困扰我?


编辑:也许我应该解释更多我在寻找什么:

关键字和技能彼此之间存在多对多关系。我不是简单地寻找得分最高的关键字,而是寻找每个关键字得分最高的技能。

我还认为我可以以某种方式使用 LIMIT 1(可能在子查询中),但到目前为止还没有想到实现它的方法。

最佳答案

我认为你已经接近第一个了...只需在 order by 之外添加一个 LIMIT 1 以将最高技能放在首位(按第 3 列排序,这是你的分数公式

-- 根据修订后的说明...我在相关 JOB ID 的层次结构中交换查询,然后找到 IT 技能和关键字而不是相反——依赖关键字技能。在您需要的情况下,您将需要一个嵌套查询...示例:

Job A has Keywords
Word A
Skill A-1 Score:90 (you want this one)
Skill A-2 Score:70
Skill A-3 Score:60
Word B
Skill B-1 Score:30
Skill B-2 Score:20
Skill B-3 Score:95 (you want this one)
Skill B-4 Score:80
Word C
Skill C-1 Score:10
Skill C-2 Score:20
Skill C-3 Score:30 (you want this one)

内部查询应该只包含关键字 ID 和关键字的最大分数——所有这些都与 questino 中的一个 Job_ID 相关联。然后,再次重新加入,但这一次,我们不再需要 job_keywords,因为每个 K.ID 和名称描述都在预查询中。然后,只需重新加入符合资格SCORE的技能即可。

SELECT STRAIGHT_JOIN
PreQuery.Keyword,
s.name as Skill,
PreQuery.Score
from
( SELECT STRAIGHT_JOIN
k.id,
k.name Keyword,
max( s.Score ) maxScore
from
jobs_keywords jk
join keywords k
on jk.keyword_id = k.id
join keyword_skills ks
on k.id = ks.keyword_id
join skills s
on ks.skill_id = s.id
where
jk.job_id = 87293
group by
k.id,
k.name ) PreQuery
join keyword_skills ks
on PreQuery.id = ks.keyword_id
join skills s
on ks.skill_id = s.id
AND PreQuery.maxScore = s.Score
order by
PreQuery.Keyword

关于mysql排序: will it work consistantly?解决方案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5747582/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com