thinkphp mysql order_order方法 - ThinkPHP5数据库实例详解 - php中文网手册

Order方法

1、功能:将数据表内容按指定字段和排序规则输出排序是非常重要的操作,无处不在,请给予足够重视

2、源码:/thinkphp/library/think/db/Query.php

08b11b5aeb7145438f6f5baca71e67cc.png

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 查询结果如下:

90971f522cf292f730dd21acfe315768.png如果将order参数修改为字符串格式:······

-> order('salary  desc')   //  以字符串方式设置结果集记录排序字段与排列顺序

······

5、总结order方法很简单,推荐参数采用数组方式。既然使用了框架,就用框架推荐的格式,否则与原生SQL语法又有什么区别呢?况且,用数组做参数,代码显得更加规范。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值