> 데이터 베이스 > MySQL 튜토리얼 > SQL에서 사용자 정의 필드 값을 어떻게 전치할 수 있습니까?

SQL에서 사용자 정의 필드 값을 어떻게 전치할 수 있습니까?

Susan Sarandon
풀어 주다: 2025-01-05 02:10:40
원래의
200명이 탐색했습니다.

How Can I Transpose User-Defined Field Values in SQL?

사용자 정의 필드 값에 대한 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿