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:
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:
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!