微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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];
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐