文章详情页
mysql -- order by 排序的疑问
问题描述
麻烦各位看看!!!注意:id是自增长的
>select * from order order by id desc,create_at asc这句是不是表明create_at这个字段没起作用了?或者说,是不是,只要在id desc之后的字段排序都不起作用??
问题解答
回答1:ORDER BY子句后面列名的顺序确定优先级的。即查询结果首先以列id的降序顺序进行排序,而只有当列id出现相同的信息时,这些相同的信息再按create_at列的升序进行排序
回答2:如果你的ID是唯一的,那么在这种情况下确实是唯一的,像这种多重排序一般适用于有重复内容的,比如说有一群人,里面有重复的姓名,我们根据姓名,再根据年龄来排序,就是如下效果
李四 20王五 22张三 17张三 18回答3:
不是的,首先对条件A id desc 排序,然后对满足条件A 之后的 条件B create_at asc 排序例如结果:
id create_at 3 42 12 32 51 11 3
id 自增 你都 1 2 3 4 5 6 7 了,后面的字段自然无法 排序了
回答4:错,当id值有重复时,会比较create_at的大小排序
相关文章:
1. javascript - 引入 simditor,但是显示标签,这个怎么解决。2. android - 目前有哪些用Vue.js开发移动App的方案?3. 为什么要通过常量的方式拐弯抹角的写呢,直接写DSN之类的不好吗4. python - scrapy获取网页指定内容,后翻到下一页继续,固定循环次数。。问题5. linux - 为公司配置服务器,要求在上面装win7的虚拟机,那我还需要装桌面环境吗?6. defined这个实验代码我这里不对哇7. theano import error (win10 python2.7)8. javascript - 网易云信整合到项目的流程9. python - 一个关于爬虫的问题10. python 发邮件
排行榜