PHP를 사용하여 일대다 연관 쿼리를 수행하는 방법
데이터베이스 작업에 PHP를 사용할 때 일대다 상관 쿼리가 필요한 경우가 많습니다. 이러한 종류의 쿼리는 한 테이블의 데이터 조각을 다른 테이블의 여러 데이터 조각과 연결할 수 있습니다. PHP에서 일대다 관계형 쿼리는 일반적으로 2차원 배열을 생성하며, 여기서 각 요소는 기본 테이블 레코드를 나타내고 해당 값은 여러 관련 테이블의 레코드입니다.
이 기사에서는 PHP를 사용하여 일대다 연관 쿼리를 수행하고 2차원 배열의 결과를 얻는 방법을 소개합니다.
1. 일대다 관련 쿼리란?
데이터베이스에서 두 테이블 사이에 기본 키와 외래 키 관계가 있으면 일대다 연관 쿼리를 수행할 수 있습니다. 이 관계에서 한 테이블의 한 레코드는 다른 테이블의 여러 레코드에 해당합니다.
예를 들어 "학생 테이블"과 "점수 테이블"이 있습니다. "학생 테이블"의 각 학생은 여러 "점수 테이블"의 기록에 해당합니다. 이 관계는 아래와 같이 기본 키와 외래 키를 사용하여 바인딩될 수 있습니다.
CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `score` ( `id` int(11) NOT NULL AUTO_INCREMENT, `student_id` int(11) DEFAULT NULL, `score` int(11) DEFAULT NULL, PRIMARY KEY (`id`), KEY `student_id` (`student_id`), CONSTRAINT `score_ibfk_1` FOREIGN KEY (`student_id`) REFERENCES `student` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
"Students 테이블"에서 각 레코드에는 고유 식별자 ID와 이름 NAME이 포함됩니다. "점수 테이블"에는 각 기록에 동일한 고유 식별자 ID와 해당 기록이 속한 학생을 나타내는 해당 STUDENT_ID가 포함되어 있으며, 학생의 점수를 나타내는 SCORE 필드도 있습니다.
2. 일대다 관련 쿼리를 수행하는 방법은 무엇입니까?
PHP에서는 JOIN 키워드를 사용하여 일대다 연관 쿼리를 수행할 수 있습니다. JOIN은 두 개 이상의 테이블에서 동일한 열을 결합하여 큰 테이블을 생성하는 데 사용되는 SQL의 키워드입니다.
위의 예에서 학생 테이블을 성적 테이블과 연결하려면 다음 SQL 문을 사용할 수 있습니다.
SELECT student.*, score.score FROM student LEFT JOIN score ON student.id = score.student_id;
이 문에서는 먼저 학생 테이블의 모든 필드를 선택한 다음 LEFT JOIN 및 ON 키 점수표와 학생표를 연결하는 단어입니다. 연결 조건은 학생 테이블의 ID 필드가 성적 테이블의 STUDENT_ID 필드와 동일하다는 것입니다. 마지막으로 SELECT문을 통해 표시할 컬럼을 선택하고 2차원 배열의 결과를 얻는다.
PHP의 PDO 객체에서는 query 메소드를 사용하여 위의 SQL 문을 실행할 수 있고, fetchAll 메소드를 사용하여 2차원 배열의 결과를 얻을 수 있습니다.
$db = new PDO('mysql:host=localhost;dbname=mydb', 'myuser', 'mypassword'); $stmt = $db->query('SELECT student.*, score.score FROM student LEFT JOIN score ON student.id = score.student_id'); $result = $stmt->fetchAll(PDO::FETCH_ASSOC);
위 코드에서는 PDO 객체가 먼저 생성됩니다. , 쿼리 메소드를 사용하여 SQL 문을 실행하고 마지막으로 fetchAll 메소드를 사용하여 결과를 가져옵니다.
3. 일대다 연관 쿼리 결과를 2차원 배열로 처리하는 방법은 무엇입니까?
일대다 연관 쿼리를 수행할 때 여러 테이블의 데이터를 2차원 배열 결과로 결합해야 합니다. 이 2차원 배열의 각 요소는 기본 테이블의 레코드를 나타내며, 해당 값은 여러 관련 테이블의 레코드입니다.
다음은 일대다 연관 쿼리 결과를 2차원 배열로 처리하는 방법입니다.
$data = array(); foreach ($result as $row) { $id = $row['id']; if (!isset($data[$id])) { $data[$id] = $row; $data[$id]['scores'] = array(); } if (!empty($row['score'])) { $data[$id]['scores'][] = $row['score']; } }
위 코드에서 먼저 최종 2차원 배열이 될 빈 배열 $data를 만듭니다. 배열 결과. 그런 다음 foreach 루프를 사용하여 쿼리 결과의 각 레코드를 순회하고 각 레코드의 기본 키 ID를 $id 변수에 저장합니다.
다음으로 $data 배열에 기본 키 $id를 가진 요소가 이미 있는지 확인하세요. 존재하지 않으면 요소가 $data 배열에 삽입되고 기본 키와 관련된 모든 레코드를 보유하기 위해 "scores"라는 빈 배열이 생성됩니다. 이미 존재하는 경우에는 삽입할 필요 없이 기존 요소를 그대로 사용합니다.
기록 순회 시 "점수 테이블"의 기록이 발견되면 해당 기록의 SCORE 필드를 점수 배열에 추가합니다. 하나의 기본 테이블 레코드는 여러 관련 테이블 레코드에 대응하므로 점수 배열을 2차원 배열로 저장해야 합니다.
루프가 끝나면 최종 2차원 배열 결과가 $data 배열에 저장됩니다. 각 요소는 기본 테이블 레코드를 나타내며 해당 값은 관련 테이블의 여러 레코드입니다.
4. 예제
다음은 일대다 연관 쿼리를 수행하고 결과를 2차원 배열로 처리하는 방법을 보여주는 전체 예제입니다.
$db = new PDO('mysql:host=localhost;dbname=mydb', 'myuser', 'mypassword'); $stmt = $db->query('SELECT student.*, score.score FROM student LEFT JOIN score ON student.id = score.student_id'); $result = $stmt->fetchAll(PDO::FETCH_ASSOC); $data = array(); foreach ($result as $row) { $id = $row['id']; if (!isset($data[$id])) { $data[$id] = $row; $data[$id]['scores'] = array(); } if (!empty($row['score'])) { $data[$id]['scores'][] = $row['score']; } } print_r($data);
위 예제에서는 먼저 PDO 개체를 만듭니다. 쿼리 메소드를 사용하여 SQL 문을 실행합니다. 그런 다음 fetchAll 메서드를 사용하여 쿼리 결과를 가져옵니다.
다음으로 foreach 루프를 사용하여 쿼리 결과의 각 레코드를 순회하고 이를 2차원 배열로 처리합니다. 마지막으로 print_r 함수를 사용하여 결과를 출력합니다.
5. 결론
이 글에서는 PHP에서 일대다 연관 쿼리를 수행하고 그 결과를 2차원 배열로 처리하는 방법을 소개합니다. 결과를 처리할 때 루프를 사용하여 쿼리 결과를 순회하고 이를 2차원 배열로 변환해야 합니다. 모든 레코드가 처리된 후 각 요소가 기본 테이블 레코드를 나타내고 해당 값은 여러 관련 테이블의 레코드인 2차원 배열의 결과를 얻을 수 있습니다.
위 내용은 PHP를 사용하여 일대다 연관 쿼리를 수행하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8의 JIT 컴파일은 자주 실행되는 코드를 컴퓨터 코드로 컴파일하여 성능을 향상시켜 계산이 많은 응용 프로그램에 도움이되고 실행 시간을 줄입니다.

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.

이 기사는 PHP의 대칭 및 비대칭 암호화에 대해 논의하여 적합성, 성능 및 보안 차이를 비교합니다. 대칭 암호화는 더 빠르고 벌크 데이터에 적합하지만 안전한 키 교환에는 비대칭이 사용됩니다.

이 기사에서는 PHP에서 강력한 인증 및 승인을 구현하여 무단 액세스를 방지하고 모범 사례를 자세히 설명하고 보안 향상 도구를 권장합니다.

이 기사는 토큰 버킷 및 누출 된 버킷과 같은 알고리즘을 포함하여 PHP에서 API 요율 제한을 구현하고 Symfony/Rate-Limiter와 같은 라이브러리 사용 전략에 대해 설명합니다. 또한 모니터링, 동적 조정 요율 제한 및 손도 다룹니다.

PHP의 준비된 진술은 컴파일 및 재사용을 통해 SQL 주입을 방지하고 쿼리 성능을 향상시켜 데이터베이스 보안 및 효율성을 향상시킵니다. 문자 수 : 159

이 기사는 MySQL 데이터베이스 상호 작용에 대한 PHP의 MySQLI_Query () 및 MySQLI_Fetch_Assoc () 함수에 대해 설명합니다. 그것은 그들의 역할, 차이점을 설명하고 그들의 사용의 실질적인 예를 제공합니다. 주요 논쟁은 USIN의 이점에 중점을 둡니다
