ORDER BY mysql逗号分隔值

时间:2012-02-20 18:14:47

标签: mysql wordpress

您好我正在尝试用逗号分隔值来命令我的数据库,但它似乎对我来说似乎没有正常工作。这是我的mysql查询。

   SELECT *
FROM wp_posts
LEFT JOIN wp_postmeta ON wp_posts.ID=wp_postmeta.post_id
LEFT JOIN wp_term_relationships ON wp_posts.ID=wp_term_relationships.object_id
LEFT JOIN wp_term_taxonomy ON wp_term_relationships.term_taxonomy_id=wp_term_taxonomy.term_id
LEFT JOIN wp_terms ON wp_term_taxonomy.term_id=wp_terms.term_id
WHERE wp_terms.name = 'Dimmers'
AND meta_key = 'feature_number_of_channels'
GROUP BY wp_posts.ID
ORDER BY meta_value  ASC

这是截图。 enter image description here 从截图中可以看出,他们似乎没有正常工作任何帮助,请问如何正确订购这些ASC ???

我正在寻找的正确的顺序是如此最高,然后像这样的ASC

24,48 - 4,6,12,24 - 12 - 6 - 6 - 3

2 个答案:

答案 0 :(得分:3)

更改ORDER BY以查看字符串的整数值:

ORDER BY CONVERT(SUBSTRING_INDEX(meta_value, ',', -1), SIGNED) DESC

以下是一个例子:

SELECT "24,38" AS meta_value UNION
SELECT 1 AS meta_value UNION
SELECT 30 AS meta_value
ORDER BY CONVERT(SUBSTRING_INDEX(meta_value, ',', -1), SIGNED) DESC

返回:

Rows = 3
meta_value
24,38
30
3
祝你好运!

答案 1 :(得分:0)

使用order table.field ASC可能对您有所帮助,因为连接的表太多了。这样服务器就可以从一个表中获取确切的顺序。