MySQL ORDER BY 当使用 name.co.uk 或 name-something.co.uk
MySQL ORDER BY when using name.co.uk or name-something.co.uk
嗨,我有我使用的代码
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
我想你要找的是 DESC,所以你的语句应该是:
按 "whatever" 描述排序
您的问题是在 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
嗨,我有我使用的代码
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
我想你要找的是 DESC,所以你的语句应该是:
按 "whatever" 描述排序
您的问题是在 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