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

标签 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

最佳答案

您的问题是在 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

关于使用 name.co.uk 或 name-something.co.uk 时的 MySQL ORDER BY,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29682171/

相关文章:

php/mysql 搜索日期并在日期是今天时发送电子邮件

MySQL ORDER BY 似乎按十六进制排序而不是按字母顺序排序

c# - 按出现次数对 IEnumerable 进行排序

oracle - Oracle ORDER BY 中将忽略与号 (&) 字符

mysql - ORDER BY ... ASC 很慢, "Using index condition"

mysql - NodeJs Mysql错误: ER_PARSE_ERROR Insert to multiple table

php - 瑞典网站上的有趣人物

php - 将随机字符串添加到 $_SESSION

java - 将 mysql 中的数据库列值与 java 中的另一个字符串进行比较

C# linq order by 和 take