您好我正在尝试用逗号分隔值来命令我的数据库,但它似乎对我来说似乎没有正常工作。这是我的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
这是截图。 从截图中可以看出,他们似乎没有正常工作任何帮助,请问如何正确订购这些ASC ???
我正在寻找的正确的顺序是如此最高,然后像这样的ASC
24,48 - 4,6,12,24 - 12 - 6 - 6 - 3
答案 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可能对您有所帮助,因为连接的表太多了。这样服务器就可以从一个表中获取确切的顺序。