>데이터 베이스 >MySQL 튜토리얼 >준비된 문을 사용하여 SQL에서 테이블을 동적으로 전치하는 방법은 무엇입니까?

준비된 문을 사용하여 SQL에서 테이블을 동적으로 전치하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-06 03:58:40746검색

How to Dynamically Transpose a Table in SQL Using Prepared Statements?

동적 SQL을 사용하여 테이블을 전치하는 방법

SQL에서 테이블을 전치하려면 행 중심의 테이블을 열 중심의 테이블로 변환해야 합니다. 이는 사용자 요약 보고서 생성과 같은 다양한 시나리오에 유용할 수 있습니다.

SQL에서 전치를 수행하는 한 가지 접근 방식은 CASE 문을 사용하는 것입니다. 제공된 예와 같이 Id, UserId, FieldName 및 FieldValue 열이 있는 테이블을 생각해 보십시오.

SELECT t.userid,
       MAX(CASE WHEN t.fieldname = 'Username' THEN t.fieldvalue ELSE NULL END) AS Username,
       MAX(CASE WHEN t.fieldname = 'Password' THEN t.fieldvalue ELSE NULL END) AS Password,
       MAX(CASE WHEN t.fieldname = 'Email Address' THEN t.fieldvalue ELSE NULL END) AS Email
FROM t
GROUP BY t.userid

이 쿼리는 사용자를 UserId별로 그룹화하고 해당 필드 값을 다음에 할당하여 전치된 결과를 반환합니다. 사용자 이름, 비밀번호 및 이메일 주소 열.

그러나 이 접근 방식을 사용하려면 각 필드에 대해 CASE 문을 정의해야 하므로 지루하고 유연성이 없을 수 있습니다. 이를 동적으로 만들려면 MySQL의 준비된 명령문(동적 SQL) 구문을 활용하면 됩니다.

SET @sql = CONCAT("SELECT userid");
-- Dynamically create the field selection part
SET @field_list = (
  SELECT GROUP_CONCAT(
    CONCAT('MAX(CASE WHEN t.fieldname = ''', fieldname, ''' THEN t.fieldvalue ELSE NULL END) AS ', fieldname)
  )
  FROM t
  GROUP BY userid
);
SET @sql = CONCAT(@sql, ", ", @field_list);

SET @sql = CONCAT(@sql, " FROM t GROUP BY userid");
PREPARE stmt FROM @sql;
EXECUTE stmt;

이 쿼리는 필드 선택 부분을 결정하기 위해 하위 쿼리의 결과를 사용하여 동적 SQL 문을 구성합니다. GROUP_CONCAT 함수를 사용하여 CASE 문을 연결함으로써 동적으로 생성된 SQL 쿼리가 유효한지 확인합니다.

동적 SQL을 활용하면 CASE 문을 수동으로 정의하지 않아도 되고 유연성을 유지할 수 있으므로 쿼리에서 모든 숫자를 처리할 수 있습니다. 사용자 정의 필드

위 내용은 준비된 문을 사용하여 SQL에서 테이블을 동적으로 전치하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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