Yii2 공동 테이블 쿼리가 개별 필드를 확인할 수 없나요?

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

테이블이 조인되지 않은 경우 개별 필드를 확인할 수 있습니다.

$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 ....
로그인 후 복사
로그인 후 복사

이게 뭐죠? 아니면 제가 사용하고 있는 방법에 문제가 있는 걸까요? ?

joinWith 외부에 select를 작성해야 합니다.

$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으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿