사용자 정의 필드 값에 대한 SQL 전치 기술
SQL에서는 행에 저장된 데이터를 다음으로 전치해야 하는 상황이 발생할 수 있습니다. 기둥을 형성하십시오. 그러한 예 중 하나는 아래 설명된 것과 같은 테이블이 있는 경우입니다.
================================================ | Id | UserId | FieldName | FieldValue | =====+========+===============+================| | 1 | 100 | Username | John Doe | |----+--------+---------------+----------------| | 2 | 100 | Password | pass123! | |----+--------+---------------+----------------| | 3 | 102 | Username | Jane | |----+--------+---------------+----------------| | 4 | 102 | Password | $ecret | |----+--------+---------------+----------------| | 5 | 102 | Email Address | [email protected] | ------------------------------------------------
이 데이터를 FieldNames가 열 헤더가 되고 FieldValues가 해당 행 데이터를 형성하는 형식으로 바꾸려면 다음 SQL 쿼리:
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 TABLE t GROUP BY t.userid
그러나 이 접근 방식이 효과적으로 작동하려면 예상되는 각 FieldName 값에 대해 CASE 문을 정의해야 합니다. 유연성을 높이려면 이러한 CASE 문을 동적으로 생성하기 위한 MySQL의 준비된 문(동적 SQL) 구문을 구현하는 것이 좋습니다.
위 내용은 SQL에서 사용자 정의 필드 값을 어떻게 전치할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!