- 常规操作
筛选a字段大于10,b字段等于10的记录并按照a降序,代码如下:
$query->where('a','>',10)->where('b','=','10')->orderBy('a','desc')->get();
常规操作就没啥好解释的了
- 非常规操作筛选
筛选a字段小于b字段的所有记录并按照a降序,
分析:排序常规操作没啥好说的,主要是筛选,要是直接写sql,那就不能利用orm了,这不是我想要的,直接用常规操作代码报错,这个时候就需要用到whereRaw()
这个方法了,具体使用请自行查阅文档,使用之后就可以在orm中嵌入sql语句,然后完美解决这个问题,代码如下:
$query->whereRaw('a < b')->orderBy('a','desc')->get();
结果:完全符合需求
- 非常规操作排序
筛选a字段小于b字段的所有记录并按照(a/b)升序
分析:这个筛选就像上边那样,关键在于排序,直接使用orderBy('a')->orderBy('b')
,结果不符合需求,使用orderBy('a/b')
代码报错,那该怎么办呢?还是类似于2的处理,使用
orderByRaw()
,该方法可用于设置原生字符串作为 order by 子句的值,代码如下:
$query->whereRaw('a < b')->orderByRaw('a/b ASC')->get();
结果:完全符合需求
总结:遇到没见过的问题,自己先尝试处理,能解决自然是最好的,解决不了只能去查看文档或者求助度娘了。