Rumah > pangkalan data > tutorial mysql > Bagaimana Mentransmisikan Baris ke Lajur dengan Cekap dalam Pelayan SQL?

Bagaimana Mentransmisikan Baris ke Lajur dengan Cekap dalam Pelayan SQL?

Barbara Streisand
Lepaskan: 2025-01-25 14:58:11
asal
332 orang telah melayarinya

How to Efficiently Transpose Rows into Columns in SQL Server?

Di SQL Server, baris secara efisien ditukar menjadi lajur

SQL Server menyediakan pelbagai kaedah untuk menukar data dari baris ke lajur.

fungsi pivot

fungsi pivot membolehkan penggunaan sintaks berikut untuk mengubah data secara langsung:

<code class="language-sql">select Firstname, Amount, PostalCode, LastName, AccountNumber
from
(
  select value, columnname
  from yourtable
) d
pivot
(
  max(value)
  for columnname in (Firstname, Amount, PostalCode, LastName, AccountNumber)
) piv;</code>
Salin selepas log masuk
Untuk situasi yang tidak diketahui bilangan lajur, anda boleh menggunakan SQL dinamik:

<code class="language-sql">DECLARE @cols AS NVARCHAR(MAX),
    @query  AS NVARCHAR(MAX)

select @cols = STUFF((SELECT ',' + QUOTENAME(ColumnName) 
                    from yourtable
                    group by ColumnName, id
                    order by id
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,1,'')

set @query = N'SELECT ' + @cols + N' from 
             (
                select value, ColumnName
                from yourtable
            ) x
            pivot 
            (
                max(value)
                for ColumnName in (' + @cols + N')
            ) p '

exec sp_executesql @query;</code>
Salin selepas log masuk
fungsi pempolimeran dan ekspresi kes

atau, anda boleh menggunakan fungsi polimer:

<code class="language-sql">select
  max(case when columnname = 'FirstName' then value end) Firstname,
  max(case when columnname = 'Amount' then value end) Amount,
  max(case when columnname = 'PostalCode' then value end) PostalCode,
  max(case when columnname = 'LastName' then value end) LastName,
  max(case when columnname = 'AccountNumber' then value end) AccountNumber
from yourtable</code>
Salin selepas log masuk
Sambungan berganda

Dalam kes lajur tertutup, anda boleh menggunakan pelbagai sambungan:

Atas ialah kandungan terperinci Bagaimana Mentransmisikan Baris ke Lajur dengan Cekap dalam Pelayan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan