Yii2联表查询不能查个别字段?

PHP中文网
풀어 주다: 2023-03-01 06:18:01
원래의
2241명이 탐색했습니다.

当不联表时,可以查个别字段。

$user->find()->select(['userid', 'username'])->asArray()->all();
로그인 후 복사
로그인 후 복사

然后SQL也很正常

select userid, username from ...
로그인 후 복사
로그인 후 복사

但联表时。。。

$user->find()
->joinWith([
    'account' => function ($object) {
        $object->select(['account_name', 'account_level', 'account_status']);
    },
    'bank' => function ($object) {
        $object->select(['bank_name', 'bank_province', 'bank_branch', 'bank_account']);
    }
])
->asArray()
->all();
로그인 후 복사
로그인 후 복사

我看了下查询SQL居然是

select * from ....
로그인 후 복사
로그인 후 복사

坑爹呢这是?还是是我用的方法有问题??

回复内容:

当不联表时,可以查个别字段。

$user->find()->select(['userid', 'username'])->asArray()->all();
로그인 후 복사
로그인 후 복사

然后SQL也很正常

select userid, username from ...
로그인 후 복사
로그인 후 복사

但联表时。。。

$user->find()
->joinWith([
    'account' => function ($object) {
        $object->select(['account_name', 'account_level', 'account_status']);
    },
    'bank' => function ($object) {
        $object->select(['bank_name', 'bank_province', 'bank_branch', 'bank_account']);
    }
])
->asArray()
->all();
로그인 후 복사
로그인 후 복사

我看了下查询SQL居然是

select * from ....
로그인 후 복사
로그인 후 복사

坑爹呢这是?还是是我用的方法有问题??

你应该把select写在joinWith外面:

$user->find()->select(['account_name', 'account_level', 'account_status', 'bank_name', 
'bank_province', 'bank_branch', 'bank_account'])
->joinWith(['account', 'bank'])
->asArray()
->all();
로그인 후 복사

当然会是 select * 因为你的操作只是在限定了查询关联表的时候会指定select字段.

所以还是向你单个的那样,指定select就好

以上就是Yii2联表查询不能查个别字段?的内容,更多相关内容请关注PHP中文网(www.php.cn)!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!