加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – Yii2按关系排序

发布时间:2020-12-13 15:55:49 所属栏目:PHP教程 来源:网络整理
导读:我有以下数据库: day: idtask: idday_task: day_id,task_id,weight 现在我想从按重量排序的特定日期获取所有任务. public function getTasks(){ return $this-hasMany(Task::className(),['id' = 'task_id'])-viaTable('day_task',['day_id' = 'id'],functi
我有以下数据库:

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 ‘,’4’.

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

解决方法

尝试在结束查询时添加orderBy

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读