繁体   English   中英

带有多个INNER JOIN的MySQL ORDER BY

[英]MySQL ORDER BY with multiple INNER JOINs

我似乎无法弄清楚如何在这个MySQL选择中订购。 我希望你能帮助我。

Tabels:

类别

catId, catParentId, catDisplay
1      0            1
2      0            1
3      0            1
4      1            1
5      1            1

categories_translation

transId, catId, catName, catDesc, langId
1        1      Title1   Desc1    1
2        2      Title2   Desc2    1
3        3      Title3   Desc3    1
4        4      Title4   Desc4    1
5        5      Title5   Desc5    1

语言

langId, langName, langCode
1       Danish    da
2       English   en

我的查询:

SELECT `categories`.`catId`,
       `categories`.`catParentId`,
       `categories`.`catDisplay`,
       `categories_translation`.`catName`,
       `categories_translation`.`catDesc`,
       `language`.`langCode`
FROM   `categories`
INNER JOIN `categories_translation` ON `categories_translation`.`catId` = `categories`.`catId`
INNER JOIN `language` ON `language`.`langId` = `categories_translation`.`langId`
WHERE `language`.`langCode` = 'da'

现在,我得到了我想要的东西,但有没有办法将子类别命令给他们的父母,所以结果如下:

期望的结果:

catId | catParentId | catDisplay | catName | catDesc | langCode
1       0             1            Title1    Desc1     da
4       1             1            Title4    Desc4     da
5       1             1            Title5    Desc5     da
2       0             1            Title2    Desc2     da
3       0             1            Title3    Desc3     da

我已经尝试过了,但似乎可以得到我想要的结果。

你不能得到你喜欢的结果,因为它不可能。 我看不到允许按照你想要的方式订购的模式或id。

为什么标题4,标题5先行?

我看不出逻辑。 也许这个例子不完整,也许CatName和CatDesc的顺序是你需要的关键。

请尝试以下方法:

ORDER BY
    CASE WHEN categories.catParentId = 0 THEN
        categories.catId
    ELSE 
        categories.catParentId
    END,
    CASE WHEN categories.catParentId = 0 THEN
        0
    ELSE
        categories.catId
    END

对于那些没有得到订单的人来说,更容易想到所需的结果:

catId | catParentId | orderingCategory
1       0             1.0
4       1             1.4
5       1             1.5
2       0             2.0
3       0             3.0

因此,它是类别的层次结构,OP希望对结果进行排序,以便每个父类别后跟其子类别。

ORDER BY catParentID, catID, ...

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM