dongya2029 2018-10-11 11:22
浏览 43
已采纳

Yii第二个查询参数

I have query to my database using Yii

$query = Task::find()
        ->where([Task::tableName().'.parent_id' => 0]);
$query->leftJoin(TaskModel::tableName(), [TaskModel::tableName().'.task_id' => Task::tableName().'.id']);
$query->andWhere([TaskModel::tableName().'.format' => null]);
$rows = $query
        ->offset($pages->offset)
        ->limit($pages->limit)
        ->orderBy([
            Task::tableName().'.status' => SORT_DESC,
            Task::tableName().'.`estimated_date`=0' => SORT_ASC,
            Task::tableName().'.estimated_date' => SORT_ASC
        ])
        ->all();

But that doesn't work, because at leftJoin, when I set relations between tables, second parameter sets string.

rawSql of my query:

SELECT `task`.* 
FROM `task` LEFT JOIN `task_model`
ON `task_model`.`task_id`='{{%task}}.id'
WHERE (`task`.`parent_id`=0) AND (`task_model`.`task_id` IS NULL)
  • 写回答

1条回答 默认 最新

  • duanlanzhi5509 2018-10-11 11:30
    关注

    You should use string in this case:

    $query->leftJoin(TaskModel::tableName(), TaskModel::tableName() . '.task_id = ' . Task::tableName() . '.id');
    

    This case is explicitly mentioned in documentation:

    Note that the array format of where() is designed to match columns to values instead of columns to columns, so the following would not work as expected: ['post.author_id' => 'user.id'], it would match the post.author_id column value against the string 'user.id'. It is recommended to use the string syntax here which is more suited for a join:

    'post.author_id = user.id'
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 目详情-五一模拟赛详情页
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b