"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 단일 MySQL 쿼리에서 여러 레코드와 관련 데이터를 가져오는 방법은 무엇입니까?

단일 MySQL 쿼리에서 여러 레코드와 관련 데이터를 가져오는 방법은 무엇입니까?

2024-11-03에 게시됨
검색:819

 How to Fetch Multiple Records and Their Related Data in a Single MySQL Query?

한 응답으로 여러 응답 데이터 반환

PHP 코드에는 데이터베이스 테이블에서 여러 행의 데이터를 가져오는 쿼리가 있습니다. . 그러나 여러 응답을 받고 있으며 이를 여러 레코드가 있는 단일 응답으로 병합하려고 합니다.

이를 달성하려면 필요한 테이블에서 왼쪽 조인을 수행하도록 쿼리를 수정해야 합니다. 학생 데이터를 가져오는 대신 주제 데이터를 가져오고 Left 조인을 사용하여 관련 학생 정보를 포함합니다. 이렇게 하면 단일 응답에 여러 테이블의 관련 데이터를 포함할 수 있습니다.

다음은 업데이트된 쿼리의 예입니다.

$sql = 'SELECT 
                subjects.userid,
                users.name AS username,
                (
                    SELECT id 
                    FROM tbsubjects 
                    WHERE userid = subjects.userid 
                    ORDER BY id ASC 
                    LIMIT 1
                ) AS subjectsid,
                (
                    SELECT name 
                    FROM tbsubjects 
                    WHERE 
                        userid = subjects.userid 
                        ORDER BY time DESC
                        LIMIT 1
                ) AS subjectname,
                (
                    SELECT IFNULL(SUM(points), 0) 
                    FROM tbsubjects 
                    WHERE 
                        userid = subjects.userid 
                        AND month = DATE_FORMAT(NOW(), "%c")
                ) AS activepts,
                IFNULL(SUM(subjects.points), 0) AS totalpts,
                (
                    SELECT IFNULL(SUM(points), 0) 
                    FROM tbsubjects 
                    WHERE 
                        userid = subjects.userid 
                        AND semester = 1
                ) AS sem1,
                (
                    SELECT IFNULL(SUM(points), 0) 
                    FROM tbsubjects 
                    WHERE 
                        userid = subjects.userid 
                        AND semester = 2
                ) AS sem2,
                (
                    SELECT IFNULL(SUM(points), 0) 
                    FROM tbsubjects 
                    WHERE 
                        userid = subjects.userid 
                        AND semester = 3
                ) AS sem3 
            FROM 
                tbsubjects AS subjects 
                LEFT JOIN tbusers AS users ON users.id = subjects.userid 
            WHERE subjects.userid = :userid GROUP BY subjects.userid ORDER BY subjects.time DESC';

이 쿼리에서:

  • FROM 절은 이제 가져올 AS 주제 tbsubjects로 시작합니다. 주제 데이터.
  • LEFT JOIN 절은 tbsubjects 테이블을 tbusers 테이블과 조인하여 해당 사용자 이름을 가져오는 데 사용됩니다.
  • 하위 쿼리는 subjectid, subjectname, activepts, totalpts를 계산하는 데 사용됩니다. 각 과목 레코드에 대한 , sem1, sem2 및 sem3 값입니다.

이 쿼리를 실행하면 각각 필요한 학생 정보와 계산된 값이 포함된 여러 과목 레코드가 포함된 단일 응답을 받게 됩니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3