php - laravel 的 Eloquent 设置排序的时候怎么以两个字段的差来排序?
PHP中文网
PHP中文网 2017-04-11 10:28:48
[PHP讨论组]

Product::where([])->orderBy('num','desc');
Product::where([])->orderBy('click','desc');

我需要 类似以“click-num”排序

PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(2)
阿神

你可以使用orderByRaw(string $sql, array $bindings = array())方法,直接把排序的sql写在第一个参数就可以了

怪我咯
-- mysql原語句
select (click-num) click_num from table order by click_num desc
// laravel寫法,如果ORM,則自行調整
DB::table('table)->selectRaw('(click-num) as click_num')->orderBy('click_num', 'desc')->get()

如果數據量大,以上性能會不佳,這塊自測吧!

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号