Sql server SQL Server使用WHILE循环添加计算列

Sql server SQL Server使用WHILE循环添加计算列,sql-server,database,while-loop,calculated-columns,Sql Server,Database,While Loop,Calculated Columns,我应该有一个专栏,每年自动更新每个成员的债务 在2013年之前,旧债务一直是6万英镑,之后变成了7.5万英镑 我在程序中还使用了一个“活动”列,如果该成员仍然处于活动状态,则将其设置为“是”,如果他停止,则将其更改为“否” 还有另一个专栏名为“pDebt”,代表已付债务 它背后的基本公式是一个简单的AmountOfDebt-PaidDebt(又名@Amount-pDebt) 我试着做那张新桌子,但有两个问题 列(l.7“dateOfRegistration”和l.10“Activity”)在存在

我应该有一个专栏,每年自动更新每个成员的债务

在2013年之前,旧债务一直是6万英镑,之后变成了7.5万英镑

我在程序中还使用了一个“活动”列,如果该成员仍然处于活动状态,则将其设置为“是”,如果他停止,则将其更改为“否” 还有另一个专栏名为“pDebt”,代表已付债务

它背后的基本公式是一个简单的AmountOfDebt-PaidDebt(又名@Amount-pDebt)

我试着做那张新桌子,但有两个问题

  • 列(l.7“dateOfRegistration”和l.10“Activity”)在存在并已在其他计算列中使用时,不断给出著名的“无效列名”

    PS:是的,我确实使用了Ctrl+Shift+R,我确实保存了查询,多次重新启动SQL Server,它仍然显示,所以我猜这是一个输入问题

  • 我无法将WHILE循环连接到ADD函数以添加新表

  • 这是我的密码

    Use [Project Alpha1]
    GO
    
    BEGIN
    
    DECLARE @Amount MONEY = 0,
    @IndividualYear int = YEAR([dateOfRegistration])
    
    ALTER TABLE initialTable
    ADD fDebt1 AS (WHILE (@IndividualYear < GETDATE() AND [Activity] = 'YES')
    BEGIN
        IF @IndividualYear = 1998 SET @Amount = @Amount + 60000
        Else
        IF @IndividualYear = 1999 SET @Amount = @Amount + 60000
        Else
        IF @IndividualYear = 2000 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2001 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2002 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2003 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2004 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2005 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2006 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2007 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2008 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2009 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2010 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2011 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2012 SET @Amount = @Amount + 60000 
        Else
        IF @IndividualYear = 2013 SET @Amount = @Amount + 60000 
        Else
            SET @Amount = @Amount + 75000
    
        SET @IndividualYear = @IndividualYear + 1
    END
    @Amount - pDebt)
    
    使用[Project Alpha1]
    去
    开始
    声明@Amount MONEY=0,
    @个人年份int=年份([注册日期])
    ALTER表初始化表
    将fDebt1添加为(WHILE(@IndividualYear
    很抱歉,我知道我没有正确地键入代码的结尾(最后一行是@Amount-pDebt),但是由于我的WHILE循环不起作用,我也不认为有必要正确地完成它,直到代码的结尾

    这是在SQL Server上进行的


    谢谢你们的阅读,伙计们,我非常感谢你们的帮助。

    一种方法是将逻辑/计算封装在一个标量函数中,这样计算字段就可以调用该函数。这样测试也会更容易

    ALTER TABLE initialTable ADD fDebt1 AS dbo.f_CalculateDebt([RegistrationDate], [Activity], [Debt])
    
    然后,标量函数可以如下所示:

    CREATE FUNCTION f_CalculateDebt(
        @RegistrationDate DATETIME,
        @Activity NVARCHAR(100),
        @Debt MONEY
    ) 
    RETURNS MONEY
    AS
    BEGIN
        DECLARE
            @Amount MONEY = 0,
            @IndividualYear INT = YEAR(@RegistrationDate)
        WHILE (@IndividualYear < YEAR(GETDATE()) AND @Activity = 'YES') BEGIN
            IF @IndividualYear = 1998
                SET @Amount = @Amount + 60000
            -- Removed for readability --
            ELSE IF @IndividualYear = 2013
                SET @Amount = @Amount + 60000 
            ELSE
                SET @Amount = @Amount + 75000
            SET @IndividualYear = @IndividualYear + 1
        END
        RETURN @Amount - @Debt
    END
    GO
    
    创建函数f_CalculateDebt(
    @注册日期日期时间,
    @活动NVARCHAR(100),
    @债款
    ) 
    还钱
    作为
    开始
    声明
    @金额=0,
    @IndividualYear INT=年份(@RegistrationDate)
    而(@IndividualYear
    我觉得这个设计很奇怪。我想他们也会付款,你会跟踪个人付款,所以你会有一些分类账表。为什么不设置一个SQL作业来运行,插入债务记录,而不是重新计算几个字段?这样,该表将始终提供帐户余额。