>백엔드 개발 >PHP 문제 >PHP를 사용하여 일대다 연관 쿼리를 수행하는 방법

PHP를 사용하여 일대다 연관 쿼리를 수행하는 방법

PHPz
PHPz원래의
2023-04-19 10:05:21949검색

데이터베이스 작업에 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.