Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Mengubah Data dalam SQL Server 2000 untuk Mengubah Data Berasaskan Baris kepada Format Berasaskan Lajur?

Bagaimanakah Saya Boleh Mengubah Data dalam SQL Server 2000 untuk Mengubah Data Berasaskan Baris kepada Format Berasaskan Lajur?

Barbara Streisand
Barbara Streisandasal
2024-12-31 18:41:11709semak imbas

How Can I Pivot Data in SQL Server 2000 to Transform Row-Based Data into a Column-Based Format?

Data Pangsi dalam SQL Server 2000: Penjelasan Terperinci

SQL Server 2000 menyediakan ciri berkuasa yang dipanggil pivoting yang membolehkan pengguna mengubah data daripada format berasaskan baris kepada format berasaskan lajur. Ini boleh berguna untuk senario di mana anda perlu meringkaskan data merentas berbilang lajur atau membuat paparan matriks data.

Pernyataan Masalah:

Dalam satu keadaan tertentu, pengguna mempunyai dua jadual:

  • Produk: Mengandungi maklumat produk asas seperti ProductId dan Nama.
  • Meta Produk: Menyimpan metadata produk dengan lajur seperti MetaKey dan MetaValue.

Pengguna memerlukan set hasil yang memaksi lajur MetaValue daripada jadual Meta Produk berdasarkan lajur MetaKey, dengan lajur ProductId dan Nama daripada jadual Produk sebagai baris pengepala.

Penyelesaian Optimum:

Untuk mencapai transformasi ini, anda boleh menggunakan pertanyaan SQL berikut:

SELECT P.ProductId, P.Name
    , MIN(CASE WHEN PM.MetaKey = 'A' THEN PM.MetaValue END) AS A
    , MIN(CASE WHEN PM.MetaKey = 'B' THEN PM.MetaValue END) AS B
    , MIN(CASE WHEN PM.MetaKey = 'C' THEN PM.MetaValue END) AS C
FROM Products AS P
JOIN ProductMeta AS PM
    ON PM.ProductId = P.ProductId
GROUP BY P.ProductId, P.Name

Penjelasan:

  • Klausa SELECT menentukan lajur untuk disertakan dalam hasil ditetapkan.
  • Fungsi agregat MIN() digunakan untuk mengembalikan nilai minimum bagi setiap MetaKey dalam setiap kumpulan ProductId dan Nama.
  • Ungkapan CASE digunakan untuk menentukan lajur (A, B, atau C) untuk mengisi berdasarkan nilai MetaKey.
  • Klausa GROUP BY menentukan lajur yang mentakrifkan baris dalam set hasil.

Nota:

Menggunakan klausa GROUP BY adalah penting dalam senario ini untuk memastikan baris dikumpulkan dengan betul. Gagal menggunakan klausa GROUP BY akan mengakibatkan keputusan berperingkat. Selain itu, setiap lajur yang tidak disertakan dalam klausa GROUP BY mesti dibalut dengan fungsi agregat (dalam kes ini, MIN()).

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengubah Data dalam SQL Server 2000 untuk Mengubah Data Berasaskan Baris kepada Format Berasaskan Lajur?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn