嗨,我的代码在我使用的地方
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发布于 2015-04-16 17:49:06
你的问题是,在α排序中,破折号先于点。
您希望只按点左边的字符进行排序。
所以:
ORDER BY left(domain_name, locate('.', domain_name)-1 ) 以下是it的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发布于 2015-04-16 17:42:49
我想你要找的是DESC,所以你的声明是:
由“任何”DESC命令
https://stackoverflow.com/questions/29682171
复制相似问题