Można użyć PIVOT
do tego. Jeśli masz znaną liczbę kolumn, a następnie można twardego kod wartości ze statycznym PIVOT:
select *
from
(
select substring(name, 1, 1) name, -- use the same field twice,
substring(name, 1, 1) initial -- once will be for the count the other for columns
from yourtable
) x
pivot
(
count(name)
for initial in ([B], [M])
) p
Zobacz SQL Fiddle With Demo
Jeśli masz nieznaną liczbę kolumn do transformacji, a następnie można użyć dynamiczny SQL i stworzyć dynamiczny PIVOT:
DECLARE @cols AS NVARCHAR(MAX),
@query AS NVARCHAR(MAX)
select @cols = STUFF((SELECT distinct ','
+ QUOTENAME(substring(name, 1, 1))
from yourtable
FOR XML PATH(''), TYPE
).value('.', 'NVARCHAR(MAX)')
,1,1,'')
set @query = 'SELECT ' + @cols + ' from
(
select substring(name, 1, 1) name,
substring(name, 1, 1) initial
from yourtable
) x
pivot
(
count(name)
for initial in (' + @cols + ')
) p '
execute(@query)
Zobacz SQL Fiddle with Demo
Jeśli następnie chcesz filtrować dane określone w dół do o Na przykład te, które zaczynają się od B or M
, można użyć klauzuli WHERE
do filtrowania.
where substring(name, 1, 1) in ('B', 'M')
Nie wiem, w jaki sposób Unia będzie Ci dwie kolumny – Paparazzi