日期:2014-05-17  浏览次数:20545 次

求存储
前面已经问过这个问题了,大家都给了我例子,可小弟不才,还是做不出来,因工作需要,帮大家帮忙!
SQL code

--------表结构---------------
CREATE TABLE [dbo].[RPT_resultA41](
    [SegtID] [int] NULL,
    [Segtname] [varchar](30) NULL,
    [acctnobe] [varchar](10) NULL,
    [acctname] [varchar](50) NULL,
    [acctid] [int] NULL,
    [acctname2] [varchar](30) NULL,
    [Mtd201301] [money] NULL,
    [Mtd201302] [money] NULL,
    [Mtd201303] [money] NULL,
    [Mtd201204] [money] NULL,
    [Mtd201205] [money] NULL,
    [Mtd201206] [money] NULL,
    [Mtd201207] [money] NULL,
    [Mtd201208] [money] NULL,
    [Mtd201209] [money] NULL,
    [Mtd201210] [money] NULL,
    [Mtd201211] [money] NULL,
    [Mtd201212] [money] NULL,
    [Ytd] [money] NULL,
    [AvgPerMth] [money] NULL,
    [BudgetYtd] [money] NULL,
    [BudgetAvgPerMth] [money] NULL,
    [VarianceUsd] [money] NULL,
    [VariancePercent] [money] NULL,
    [LastYrYtd] [money] NULL,
    [LastYrAvgPerMth] [money] NULL,
    [classify] [int] NULL,
    [Subtotal] [int] NULL,
    [CompanyID] [int] NULL,
    [UserID] [int] NULL,
    [DateCreated] [datetime] NULL

---------------需求-------------------


SQL code
---建一个下面的存储,补充as后面的 
create proc PRT_41
(@Cid varchar,----字段CompanyID
@beginyear int,----开始年份(例如:字段'Mtd201204'中的2012)
@beginmonth int,----开始月份(例如:字段'Mtd201204'中的04)
@endyear int,-----结束年份
@ednmonth int)----结束月份
as
--- 1  实现当输入exec PRT_41 1,2012,2,2012,4时就输出CompanyID=1的2012年2月到4月的数据,
----2  除了不在范围的月份,其他字段保留,像SegID,acctname等(月份字段也可以保留,但不能有数据)
----3  如果可以,YTD的数是前面所显示的月份数据相加!


------解决方案--------------------
首先表的设计有一些问题吧,如果这么设计:
[SegtID] [int] NULL,
[Segtname] [varchar](30) NULL,
[acctnobe] [varchar](10) NULL,
[acctname] [varchar](50) NULL,
[acctid] [int] NULL,
[acctname2] [varchar](30) NULL,
时间 varchar(10),
金额 money,
[Ytd] [money] NULL,
[AvgPerMth] [money] NULL,
[BudgetYtd] [money] NULL,
[BudgetAvgPerMth] [money] NULL,
[VarianceUsd] [money] NULL,
[VariancePercent] [money] NULL,
[LastYrYtd] [money] NULL,
[LastYrAvgPerMth] [money] NULL,
[classify] [int] NULL,
[Subtotal] [int] NULL,
[CompanyID] [int] NULL,
[UserID] [int] NULL,
[DateCreated] [datetime] NULL

问题是不是能变得简单一些呢?当然不了解具体需求,只是猜测而已
------解决方案--------------------
探讨

引用:
首先表的设计有一些问题吧,如果这么设计:
[SegtID] [int] NULL,
[Segtname] [varchar](30) NULL,
[acctnobe] [varchar](10) NULL,
[acctname] [varchar](50) NULL,
[acctid] [int] NULL,
[acctname2] [varchar](3……

------解决方案--------------------
貌似就是一个动态拼接字段



SQL code
IF OBJECT_ID('[PRT_41]',N'P') IS NOT NULL DROP PROC [PRT_41]
GO 
create proc PRT_41
(@Cid varchar,----字段CompanyID
@beginyear int,----开始年份(例如:字段'Mtd201204'中的2012)
@beginmonth int,----开始月份(例如:字段'Mtd201204'中的04)
@endyear int,-----结束年份
@ednmonth int)----结束月份
AS
BEGIN 
    DECLARE @col VARCHAR(1000),@total VARCHAR(1000),@sql VARCHAR(1000)
    WHILE @beginmonth<=@ednmonth
        BEGIN 
            SET @col=ISNULL(@col+',','')+'[Mtd2012'+RIGHT(100+@beginmonth,2)+']'
            SET @total=ISNULL(@total+'+','')+'[Mtd2012'+RIGHT(100+@beginmonth,2)+']'
            SET @beginmonth=@beginmonth+1
        END 
    SET @col='[SegtID],[Segtname],[acctnobe],[acctname],[acctid],[acctname2],'+@col+',[total]='+@total
    SET @col=@col+',[Ytd],[AvgPerMth],[BudgetYtd], [BudgetAvgPerMth], [VarianceUsd],[VariancePercent]'
    SET @col=@col+',[LastYrYtd],[LastYrAvgPerMth],[classify] ,[Subtotal] ,[C