SQL Pivot with multiple header
I'm doing pivot with multiple headers in SP.
I pivoting date into 3 column(WLQ, TQ & FLQ).
The problem after doing pivoting is the column is display by the group.
Example output is: (12-4_WLQ, 13-4_WLQ, 14-4_WLQ, 12-4_TQ, 13-4_TQ, 14-4_TQ, 12-4_FLQ, 13-4_FLQ, 14-4_FLQ)
.
how I want to display the output by date like this: (12-4_WLQ, 12-4_TQ, 12-4_FLQ, 13-4_WLQ, 13-4_TQ, 13-4_FLQ, 14-4_WFLQ, 14-4_TQ, 14-4_FLQ)
Here is my code:
ALTER PROCEDURE [dbo].[EXEC_DATETM_SP]
AS
BEGIN
SET NOCOUNT ON;
DECLARE @DynamicPivotQuery AS NVARCHAR(MAX)
DECLARE @startdt DATETIME, @enddt DATETIME, @QueryCol NVARCHAR(MAX), @QueryCol2 NVARCHAR(MAX), @QueryCol3 NVARCHAR(MAX)
SET @startdt = '04/12/2018'
SET @enddt = '04/17/2018'
WHILE @startdt <= @enddt
BEGIN
SET @QueryCol=isnull(@QueryCol, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_WLQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @QueryCol2=isnull(@QueryCol2, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_TQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @QueryCol3=isnull(@QueryCol3, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_FLQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @startdt = @startdt + 1
END
set @DynamicPivotQuery=
N'
select
[KT_HYOU_NAME],
[KT_KEIRO_NAME],
[KT_GUN_NO],
[TUKA_JUN],
[KT_CD],
[SG_KU_CD],
' + @QueryCol + ',
' + @QueryCol2 + ',
' + @QueryCol3 + '
from
(
SELECT * FROM V_DATEBYWLQ
)s
pivot (sum (WORK_LOT_QTY) for
[EXEC_DATETMM] in ('+@QueryCol+')) as AvgWidgetsPerDayPerEmp
pivot (sum (TARGET_QTY) for
[EXEC_DATETMN] in ('+@QueryCol2+')) as AvgWidgetsPerDayPerEmp2
pivot (sum (FIN_LOT_QTY) for
[EXEC_DATETMO] in ('+@QueryCol3+')) as AvgWidgetsPerDayPerEmp3
'
EXEC sp_executesql @DynamicPivotQuery
END
GO
pivot
add a comment |
I'm doing pivot with multiple headers in SP.
I pivoting date into 3 column(WLQ, TQ & FLQ).
The problem after doing pivoting is the column is display by the group.
Example output is: (12-4_WLQ, 13-4_WLQ, 14-4_WLQ, 12-4_TQ, 13-4_TQ, 14-4_TQ, 12-4_FLQ, 13-4_FLQ, 14-4_FLQ)
.
how I want to display the output by date like this: (12-4_WLQ, 12-4_TQ, 12-4_FLQ, 13-4_WLQ, 13-4_TQ, 13-4_FLQ, 14-4_WFLQ, 14-4_TQ, 14-4_FLQ)
Here is my code:
ALTER PROCEDURE [dbo].[EXEC_DATETM_SP]
AS
BEGIN
SET NOCOUNT ON;
DECLARE @DynamicPivotQuery AS NVARCHAR(MAX)
DECLARE @startdt DATETIME, @enddt DATETIME, @QueryCol NVARCHAR(MAX), @QueryCol2 NVARCHAR(MAX), @QueryCol3 NVARCHAR(MAX)
SET @startdt = '04/12/2018'
SET @enddt = '04/17/2018'
WHILE @startdt <= @enddt
BEGIN
SET @QueryCol=isnull(@QueryCol, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_WLQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @QueryCol2=isnull(@QueryCol2, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_TQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @QueryCol3=isnull(@QueryCol3, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_FLQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @startdt = @startdt + 1
END
set @DynamicPivotQuery=
N'
select
[KT_HYOU_NAME],
[KT_KEIRO_NAME],
[KT_GUN_NO],
[TUKA_JUN],
[KT_CD],
[SG_KU_CD],
' + @QueryCol + ',
' + @QueryCol2 + ',
' + @QueryCol3 + '
from
(
SELECT * FROM V_DATEBYWLQ
)s
pivot (sum (WORK_LOT_QTY) for
[EXEC_DATETMM] in ('+@QueryCol+')) as AvgWidgetsPerDayPerEmp
pivot (sum (TARGET_QTY) for
[EXEC_DATETMN] in ('+@QueryCol2+')) as AvgWidgetsPerDayPerEmp2
pivot (sum (FIN_LOT_QTY) for
[EXEC_DATETMO] in ('+@QueryCol3+')) as AvgWidgetsPerDayPerEmp3
'
EXEC sp_executesql @DynamicPivotQuery
END
GO
pivot
add a comment |
I'm doing pivot with multiple headers in SP.
I pivoting date into 3 column(WLQ, TQ & FLQ).
The problem after doing pivoting is the column is display by the group.
Example output is: (12-4_WLQ, 13-4_WLQ, 14-4_WLQ, 12-4_TQ, 13-4_TQ, 14-4_TQ, 12-4_FLQ, 13-4_FLQ, 14-4_FLQ)
.
how I want to display the output by date like this: (12-4_WLQ, 12-4_TQ, 12-4_FLQ, 13-4_WLQ, 13-4_TQ, 13-4_FLQ, 14-4_WFLQ, 14-4_TQ, 14-4_FLQ)
Here is my code:
ALTER PROCEDURE [dbo].[EXEC_DATETM_SP]
AS
BEGIN
SET NOCOUNT ON;
DECLARE @DynamicPivotQuery AS NVARCHAR(MAX)
DECLARE @startdt DATETIME, @enddt DATETIME, @QueryCol NVARCHAR(MAX), @QueryCol2 NVARCHAR(MAX), @QueryCol3 NVARCHAR(MAX)
SET @startdt = '04/12/2018'
SET @enddt = '04/17/2018'
WHILE @startdt <= @enddt
BEGIN
SET @QueryCol=isnull(@QueryCol, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_WLQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @QueryCol2=isnull(@QueryCol2, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_TQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @QueryCol3=isnull(@QueryCol3, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_FLQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @startdt = @startdt + 1
END
set @DynamicPivotQuery=
N'
select
[KT_HYOU_NAME],
[KT_KEIRO_NAME],
[KT_GUN_NO],
[TUKA_JUN],
[KT_CD],
[SG_KU_CD],
' + @QueryCol + ',
' + @QueryCol2 + ',
' + @QueryCol3 + '
from
(
SELECT * FROM V_DATEBYWLQ
)s
pivot (sum (WORK_LOT_QTY) for
[EXEC_DATETMM] in ('+@QueryCol+')) as AvgWidgetsPerDayPerEmp
pivot (sum (TARGET_QTY) for
[EXEC_DATETMN] in ('+@QueryCol2+')) as AvgWidgetsPerDayPerEmp2
pivot (sum (FIN_LOT_QTY) for
[EXEC_DATETMO] in ('+@QueryCol3+')) as AvgWidgetsPerDayPerEmp3
'
EXEC sp_executesql @DynamicPivotQuery
END
GO
pivot
I'm doing pivot with multiple headers in SP.
I pivoting date into 3 column(WLQ, TQ & FLQ).
The problem after doing pivoting is the column is display by the group.
Example output is: (12-4_WLQ, 13-4_WLQ, 14-4_WLQ, 12-4_TQ, 13-4_TQ, 14-4_TQ, 12-4_FLQ, 13-4_FLQ, 14-4_FLQ)
.
how I want to display the output by date like this: (12-4_WLQ, 12-4_TQ, 12-4_FLQ, 13-4_WLQ, 13-4_TQ, 13-4_FLQ, 14-4_WFLQ, 14-4_TQ, 14-4_FLQ)
Here is my code:
ALTER PROCEDURE [dbo].[EXEC_DATETM_SP]
AS
BEGIN
SET NOCOUNT ON;
DECLARE @DynamicPivotQuery AS NVARCHAR(MAX)
DECLARE @startdt DATETIME, @enddt DATETIME, @QueryCol NVARCHAR(MAX), @QueryCol2 NVARCHAR(MAX), @QueryCol3 NVARCHAR(MAX)
SET @startdt = '04/12/2018'
SET @enddt = '04/17/2018'
WHILE @startdt <= @enddt
BEGIN
SET @QueryCol=isnull(@QueryCol, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_WLQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @QueryCol2=isnull(@QueryCol2, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_TQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @QueryCol3=isnull(@QueryCol3, '')+QUOTENAME(convert(nvarchar(20), @startdt, 101)+'_FLQ')+(CASE WHEN @startdt<>@enddt THEN ',' ELSE '' END)
SET @startdt = @startdt + 1
END
set @DynamicPivotQuery=
N'
select
[KT_HYOU_NAME],
[KT_KEIRO_NAME],
[KT_GUN_NO],
[TUKA_JUN],
[KT_CD],
[SG_KU_CD],
' + @QueryCol + ',
' + @QueryCol2 + ',
' + @QueryCol3 + '
from
(
SELECT * FROM V_DATEBYWLQ
)s
pivot (sum (WORK_LOT_QTY) for
[EXEC_DATETMM] in ('+@QueryCol+')) as AvgWidgetsPerDayPerEmp
pivot (sum (TARGET_QTY) for
[EXEC_DATETMN] in ('+@QueryCol2+')) as AvgWidgetsPerDayPerEmp2
pivot (sum (FIN_LOT_QTY) for
[EXEC_DATETMO] in ('+@QueryCol3+')) as AvgWidgetsPerDayPerEmp3
'
EXEC sp_executesql @DynamicPivotQuery
END
GO
pivot
pivot
edited Nov 15 '18 at 5:58
farhana
2,57252234
2,57252234
asked Nov 15 '18 at 3:20
MunirahMunirah
12
12
add a comment |
add a comment |
0
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53311920%2fsql-pivot-with-multiple-header%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53311920%2fsql-pivot-with-multiple-header%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown