mysql 的 order bu 后面如果不跟列名,还可以跟什么

谁学逆向工程 2018-04-12 04:49:54
我这里有3个语句,分别对应3个结果,sal 字段是double 类型

select * From t_employee2 Where sal in (1500,800,1600)
order by instr(',1500.00,800.00,1600.00,',CONCAT(',',sal,','));

SELECT CONCAT(',',sal,',') From t_employee2;

SELECT DISTINCT instr(',1500.00,800.00,1600.00,',CONCAT(',',sal,',')) From t_employee2;









从这运行结果看,我猜 order by 后面跟的好像是数值数组,因为 instr 返回的是数值么,然后我尝试下面的代码,报错了




所以我想问 order by 后面除了列名还可以怎么用
...全文
854 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
骏马金龙 2018-04-22
  • 打赏
  • 举报
回复
除了字段名称、select列表中字段顺序号(数字)和null。就这三种
谁学逆向工程 2018-04-20
  • 打赏
  • 举报
回复
引用 1 楼 ckc 的回复:
不需要括号,直接用数字,1,2,3这样就可以,代表你在前面select的列的序号

这两个查询结果都是一样的

ckc 2018-04-13
  • 打赏
  • 举报
回复
不需要括号,直接用数字,1,2,3这样就可以,代表你在前面select的列的序号

56,675

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧