MySQL ORDER BY使用name.co.uk或name-something.co.uk

时间:2015-04-16 17:39:44

标签: mysql sql-order-by

嗨我的代码在哪里使用

ORDER BY domain_name ASC

并获得类似

的结果
name-somethinga.co.uk
name-somethingb.co.uk
name.co.uk
papa-alpha.co.uk
papa.co.uk

我想知道的是可以得到像

这样的结果
name.co.uk
name-somethinga.co.uk
name-somethingb.co.uk
papa.co.uk
papa-alpha.co.uk

2 个答案:

答案 0 :(得分:0)

我认为你所寻找的是DESC,所以你的陈述是:

ORDER BY"无论什么" DESC

答案 1 :(得分:0)

你的问题是在alpha排序中,破折号出现在点之前。

您只想通过点左侧的字符进行排序。

所以:

ORDER BY left(domain_name, locate('.', domain_name)-1 ) 

这是一个SQLFiddle:http://sqlfiddle.com/#!9/aa4bc/1

此版本显示您要排序的内容:

select *, left(domain_name, locate('.', domain_name)-1 ) as sortname
from sites
ORDER BY left(domain_name, locate('.', domain_name)-1 ) ASC;

给出:

id  domain_name             sortname
3   name.co.uk              name
1   name-somethinga.co.uk   name-somethinga
2   name-somethingb.co.uk   name-somethingb
4   papa.co.uk              papa
5   papa-alpha.co.uk        papa-alpha