Vous pouvez facilement diviser le YP
chaîne utilisant LEFT()
, RIGHT()
, SUBSTRING()
, etc. Ma suggestion serait de savoir comment vous gérez votre UNPIVOT
. Il semble que vous ayez beaucoup de colonnes à UNPIVOT
donc ma suggestion pourrait être d'implémenter SQL dynamique pour effectuer cette requête. Vous procéderiez ainsi :
declare @colsUnpivot varchar(max),
@query AS NVARCHAR(MAX),
@cols varchar(max)
select @colsUnpivot = stuff((select ','
+quotename(replace(C.name, 'Qty', ''))
from sys.columns as C
where C.object_id = object_id('yourtable') and
C.name like 'Qty%'
for xml path('')), 1, 1, '')
select @cols = stuff((select ','
+quotename(C.name) + ' as ' + replace(C.name, 'Qty', '')
from sys.columns as C
where C.object_id = object_id('yourtable') and
C.name like 'Qty%'
for xml path('')), 1, 1, '')
set @query
= 'select rowid,
left(YP, 1) YP,
cast(right(YP, len(YP) - 1) as int) period,
Val
from
(
select rowid, ' + @cols + '
from yourtable
) x1
unpivot
(
val for YP IN (' + @colsUnpivot + ')
) u'
exec(@query)