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를 사용한다는 뜻으로 주 정보를 확정할 때 조건에 부합되는 부표 정보를 나열하여 단일 또는 소량의 주 정보 또는 주 정보 선별에 적합하다

좋은 웹페이지 즐겨찾기