php – Yii2按关系排序

我有以下数据库

day: id
task: id
day_task: day_id, task_id, weight

现在我想从按重量排序的特定日期获取所有任务.

public function getTasks()
{
    return $this->hasMany(Task::className(), ['id' => 'task_id'])->viaTable('day_task', ['day_id' => 'id'], function ($query) {
        $query->orderBy(['weight' => SORT_ASC]);
    });
}

导致:

SELECT * FROM `day_task` WHERE `day_id`=2 ORDER BY `weight`
SELECT * FROM `task` WHERE `id` IN ('2', '1', '3', '4')

问题是DBMS返回存储在表中的行而不考虑IN的顺序,所以我得到’1′,’2′,’3′,’4’而不是’2′,’1 ‘,’3′,’4’.

除了手动逐行取出之外,我找不到任何解决方案.

解决方法:

尝试在结束查询添加orderBy

public function getTasks()
{
   return $this->hasMany(Task::className(), ['id' => 'task_id'])- >viaTable('day_task', ['day_id' => 'id'])->orderBy(['weight' => SORT_ASC];
}

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...