laravel의 관련 검색 with 문제
4923 단어 laravel
표 구조
:
Create Table
CREATE TABLE `user` (
`uid` mediumint(8) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
`email` varbinary(255) NOT NULL,
PRIMARY KEY (`uid`)
) ENGINE=InnoDB AUTO_INCREMENT=114001 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci
:
CREATE TABLE `user_options` (
`id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT,
`uid` mediumint(8) unsigned NOT NULL,
`age` tinyint(3) NOT NULL,
`sex` tinyint(1) NOT NULL,
PRIMARY KEY (`id`),
KEY `options_key` (`uid`)
) ENGINE=InnoDB AUTO_INCREMENT=114001 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci
seed를 사용하여 무작위 데이터 10W 줄 삽입
테스트
각각 User, Options 모델을 구축하고 일대일 관계를 구축합니다.
코드는 다음과 같습니다.
User::with(['options'=>function($query){
$query->where('sex','=','1');
}])->paginate(15);
laravel의 debug 모니터링된 SQL 실행은 다음과 같습니다.
select count(*) as aggregate from `user`
select * from `user` limit 15 offset 0
select * from `user_options` where `user_options`.`uid` in ('1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '13', '14', '15') and `sex` = '1'
결론
만약 부표의 필터를 사용하여 목록을 선별해야 한다면, with를 사용하면 좋지 않을 것입니다!with를 사용한다는 뜻으로 주 정보를 확정할 때 조건에 부합되는 부표 정보를 나열하여 단일 또는 소량의 주 정보 또는 주 정보 선별에 적합하다
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Laravel - 변환된 유효성 검사 규칙으로 API 요청 제공동적 콘텐츠를 위해 API를 통해 Laravel CMS에 연결하는 모바일 앱(또는 웹사이트) 구축을 고려하십시오. 이제 앱은 CMS에서 번역된 콘텐츠를 받을 것으로 예상되는 다국어 앱이 될 수 있습니다. 일반적으로 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.