찾다
일일 프로그램MySQL 지식데이터베이스 N+1 쿼리 문제 해결

데이터베이스 N+1 쿼리 문제 해결

Jun 19, 2019 am 09:40 AM
데이터 베이스

데이터베이스 N+1 쿼리 문제 해결

Requirements

데이터 테이블은 다음과 같습니다.

department table

|id|name|

user table

|id|name|department_id|

요구 사항은 다음 구조의 데이터를 가져오는 것입니다. :

[
    {        "id":1,        "name":"test",        "department_id":1,        "department":{            "id":1,            "name":"测试部门"
        }
    }
]

방법 1 :루프 쿼리

  1. 사용자 목록 쿼리

  2. 사용자 목록을 루프하여 해당 부서 정보를 쿼리

$users = $db->query('SELECT * FROM `user`');foreach($users as &$user) {
    $users['department'] = $db->query('SELECT * FROM `department` WHERE `id` = '.$user['department_id']);
}

이 방법의 쿼리 수는 1+N(쿼리 한 번 나열하고 부서를 N 번 쿼리), 성능이 가장 낮으므로 권장되지 않습니다.

方法二:连表

  1. 通过连表查询用户和部门数据

  2. 处理返回数据

$users = $db->query('SELECT * FROM `user` INNER JOIN `department` ON `department`.`id` = `user`.`department_id`');// 手动处理返回结果为需求结构

该方法其实也有局限性,如果 user 和 department 不在同一个服务器是不可以连表的。

方法三:1+1查询

  1. 该方法先查询1次用户列表

  2. 取出列表中的部门ID组成数组

  3. 查询步骤2中的部门

  4. 合并最终数据

代码大致如下:

$users = $db->query('SELECT * FROM `user`');
$departmentIds =[ ];foreach($users as $user) {    if(!in_array($user['department_id'], $departmentIds)) {
        $departmentIds[] = $user['department_id'];
    }
}
$departments = $db->query('SELECT * FROM `department` WHERE id in ('.join(',',$department_id).')');
$map = []; // [部门ID => 部门item]foreach($departments as $department) {
    $map[$department['id']] = $department;
}foreach($users as $user) {
    $user['department'] = $map[$user['department_id']] ?? null;
 }

该方法对两个表没有限制,在目前微服务盛行的情况下是比较好的一种做法。

更多MySQL相关技术文章,请访问MySQL教程栏目进行学习!

위 내용은 데이터베이스 N+1 쿼리 문제 해결의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
무단 액세스에 대해 MySQL 서버를 어떻게 보호합니까?무단 액세스에 대해 MySQL 서버를 어떻게 보호합니까?Mar 20, 2025 pm 03:20 PM

이 기사는 비밀번호 관리를 통한 무단 액세스에 대한 MySQL 서버 보안, 원격 액세스 제한, 암호화 사용 및 정기 업데이트에 대해 설명합니다. 또한 보안을 향상시키기위한 의심스러운 활동 모니터링 및 감지에도 다룹니다.

역할을 사용하여 사용자 권한을 어떻게 관리합니까?역할을 사용하여 사용자 권한을 어떻게 관리합니까?Mar 20, 2025 pm 03:19 PM

이 기사는 역할을 사용하여 사용자 권한을 효율적으로 관리하고 역할 정의, 권한 할당 및 동적 조정을 자세히 설명합니다. 역할 기반 액세스 제어를위한 모범 사례와 역할이 사용자 관리 ACR을 단순화하는 방법을 강조합니다.

MySQL에서 사용자 계정의 비밀번호를 어떻게 설정합니까?MySQL에서 사용자 계정의 비밀번호를 어떻게 설정합니까?Mar 20, 2025 pm 03:18 PM

이 기사에서는 MySQL 사용자 계정 암호를 설정 및 보호하는 방법, 비밀번호 보안에 대한 모범 사례, 원격 암호 변경 및 비밀번호 정책 준수 보장에 대해 설명합니다.

MySQL의 다른 유형의 권한은 무엇입니까?MySQL의 다른 유형의 권한은 무엇입니까?Mar 20, 2025 pm 03:16 PM

기사는 MySQL 권한 : 글로벌, 데이터베이스, 테이블, 열, 루틴 및 프록시 사용자 유형에 대해 설명합니다. 보안 관리를위한 부여, 취소 특권 및 모범 사례를 설명합니다. 과잉 사례 위험이 강조됩니다.

보조금 진술서를 사용하여 사용자에게 권한을 부여하는 방법은 무엇입니까?보조금 진술서를 사용하여 사용자에게 권한을 부여하는 방법은 무엇입니까?Mar 20, 2025 pm 03:15 PM

이 기사는 SQL에서 보조금 명세서를 사용하여 특정 데이터베이스 개체의 사용자 또는 역할에 대한 Select, Insert 및 업데이트와 같은 다양한 권한을 할당합니다. 또한 취소 성명서와 함께 취소 된 특권과 특권 부여도 다루고 있습니다.

Create 사용자 명령문을 사용하여 MySQL에서 사용자를 어떻게 생성합니까?Create 사용자 명령문을 사용하여 MySQL에서 사용자를 어떻게 생성합니까?Mar 20, 2025 pm 03:14 PM

기사는 사용자 명령문 작성, 권한 할당, 암호 설정 및 사용자 이름 선택으로 MySQL 사용자 생성에 대해 논의합니다.

저장된 절차 및 기능을 실행하도록 권한을 부여하는 방법은 무엇입니까?저장된 절차 및 기능을 실행하도록 권한을 부여하는 방법은 무엇입니까?Mar 20, 2025 pm 03:12 PM

기사는 보안 된 다중 사용자 데이터베이스 관리를위한 SQL 명령 및 모범 사례에 중점을 둔 저장된 절차 및 기능에 대한 실행 권한 부여에 대해 논의합니다.

저장된 절차 또는 기능에서 저장된 절차를 어떻게 호출합니까?저장된 절차 또는 기능에서 저장된 절차를 어떻게 호출합니까?Mar 20, 2025 pm 03:11 PM

이 기사에서는 SQL Server에 중점을 둔 다른 저장된 절차 또는 기능 내에서 저장된 절차를 호출하는 것에 대해 논의합니다. 구문, 모듈성 및 보안, 오류 처리 및 중첩 프로 시저의 디자인 고려 사항과 같은 이점을 다룹니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기