Welcome to OStack Knowledge Sharing Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
4.0k views
in Technique[技术] by (71.8m points)

yii2使用joinwith 子表数据为null,添加asArray后,正常,询问下原因?

image

image

$list = orderExtra::find()->joinWith('visitor')->where([]);
//        $list = $list->asArray()->all();
         $list = $list->all();

子表关联语句:
使用身份证号进行关联,身份证号是唯一索引

public function getVisitor() {
 return $this->hasone(Visitor::className(), ['card_num' => 'v_card_num']);
}

关联表已有,
使用上面两个语句进行查询:

  • 使用asArray时,子表visitor会有数据产生,反之则没有

问题可以使用添加asArray解决,但不知道问题出在哪里,以及不知道要去哪里查找问题,请教有没有大佬可以给出点意见


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Answer

0 votes
by (71.8m points)

你看,你不用asArray的时候,你的_related这个属性是空,你最好从这个方向查下,正常来讲,这个属性下应该就是你子表的对象数据


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome to OStack Knowledge Sharing Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...