Order方法
1、功能:将数据表内容按指定字段和排序规则输出排序是非常重要的操作,无处不在,请给予足够重视
2、源码:/thinkphp/library/think/db/Query.php
3、参数与返回值参数序号参数说明1$string / 字符串将排序字段与排序规则写在一个字符串中:order( 'age desc' )
2$array / 数组以排序字段为元素键名,排序规则为元素值:order([ 'age' => 'desc'])返回值:同样也是返回Query查询类对象
4、实例演示
任务1:查询tp5_staff表中工资大于9500元的员工信息(姓名与工资)本例中所有方法的参数,全部以数组形式给出Index.php 控制器代码:<?php
namespace app\index\controller;
//导入数据库类
use think\Db;
class Index {
public function index(){
//查询tp5_staff表中工资大于9500元的员工信息(姓名与工资)
$result = Db::table('tp5_staff') // 选择数据表
-> field(['name' => '姓名','salary' => '工资']) //设置字段与字段别名
-> where(['salary'=>['>',9500]]) //设置过滤条件
-> order(['salary' => 'desc']) // 设置结果集记录排序字段与排列顺序
->select(); // 输出结果集
//查看结果
dump($result);
}
}查询输出:array(4) {
[0] => array(2) {
["姓名"] => string(9) "西门庆"
["工资"] => float(19801)
}
[1] => array(2) {
["姓名"] => string(6) "方方"
["工资"] => float(9877)
}
[2] => array(2) {
["姓名"] => string(9) "李云龙"
["工资"] => float(9850)
}
[3] => array(2) {
["姓名"] => string(9) "段王爷"
["工资"] => float(9560)
}
}对应的SQL语句:SELECT `name` AS `姓名`,`salary` AS `工资` FROM `tp5_staff` WHERE `salary` > 9500 ORDER BY `salary` descSQLPRO 查询结果如下:
如果将order参数修改为字符串格式:······
-> order('salary desc') // 以字符串方式设置结果集记录排序字段与排列顺序
······
5、总结order方法很简单,推荐参数采用数组方式。既然使用了框架,就用框架推荐的格式,否则与原生SQL语法又有什么区别呢?况且,用数组做参数,代码显得更加规范。