我正在使用 SQLServer2008。
下面是我的存储过程
DECLARE @planTable TABLE
(
Year VARCHAR(20) ,
PlanTypeId INT
)
INSERT INTO @planTable
( Year ,
PlanTypeId
)
( SELECT DISTINCT
pm.Year ,
ptm.PlanTypeId
FROM dbo.PlanMaster AS pm
INNER JOIN dbo.PlanTypeMaster AS ptm ON pm.PlanTypeId = ptm.PlanTypeId
)
DECLARE @tmp TABLE
(
BrokerCode VARCHAR(20) ,
Year VARCHAR(20) ,
PlanType VARCHAR(20) ,
Amount DECIMAL(18, 2)
)
DECLARE @Year VARCHAR(20)
DECLARE @PlanTypeId INT
DECLARE c1 CURSOR READ_ONLY
FOR
SELECT pt.Year,pt.PlanTypeId FROM @planTable AS pt
OPEN c1
FETCH NEXT FROM c1
INTO @Year,@PlanTypeId
WHILE @@FETCH_STATUS = 0
BEGIN
INSERT INTO @tmp
( BrokerCode ,
Year ,
PlanType ,
Amount
)
( SELECT ( SELECT bm.BrokerCode
FROM dbo.BrokerMaster AS bm
WHERE BrokerId = 30
) ,
@Year ,
( CASE WHEN ( SELECT ptm.IsSingleInstallment
FROM dbo.PlanTypeMaster AS ptm
WHERE ptm.PlanTypeId = @PlanTypeId
) = 'true' THEN 'Single'
WHEN ( SELECT ptm.IsSingleInstallment
FROM dbo.PlanTypeMaster AS ptm
WHERE ptm.PlanTypeId = @PlanTypeId
) = 'false' THEN 'Multiple'
END ) ,
ISNULL(( SUM(SelfAmount) + SUM(UnitAmount) ), 0)
FROM dbo.MemberBusiness AS mb
INNER JOIN dbo.PlanMaster AS pm ON mb.PlanId = pm.PlanId
INNER JOIN dbo.PlanTypeMaster AS ptm2 ON pm.PlanTypeId = ptm2.PlanTypeId
WHERE mb.BrokerId = 30
AND pm.Year = @Year
AND ptm2.PlanTypeId = @PlanTypeId
)
FETCH NEXT FROM c1
INTO @Year,@PlanTypeId
END
CLOSE c1
DEALLOCATE c1
SELECT *
FROM @tmp
这个存储过程的结果是这样的
----------------------------------------------------
BrokerCode | Year | PlanType | Amount |
----------------------------------------------------
102 | 1 | Single | 100 |
----------------------------------------------------
102 | 2 | Single | 200 |
----------------------------------------------------
102 | 3 | Single | 300 |
----------------------------------------------------
102 | 1 | Multiple | 100 |
----------------------------------------------------
102 | 2 | Multiple | 200 |
----------------------------------------------------
102 | 3 | Multiple | 300 |
现在我想得到这样的结果..
------------------------------------------------------------------------------------
Single | Multiple |
-------------------------------------------------------------------------------------
BrokerCode | 1 | 2 | 3 | 1 | 2 | 3 |
------------------------------------------------------------------------------------
102 | 100 | 200 | 300 | 100 | 200 | 300 |
------------------------------------------------------------------------------------
我怎样才能得到这样的结果?