Sql server SQL Server使用WHILE循环添加计算列
我应该有一个专栏,每年自动更新每个成员的债务 在2013年之前,旧债务一直是6万英镑,之后变成了7.5万英镑 我在程序中还使用了一个“活动”列,如果该成员仍然处于活动状态,则将其设置为“是”,如果他停止,则将其更改为“否” 还有另一个专栏名为“pDebt”,代表已付债务 它背后的基本公式是一个简单的AmountOfDebt-PaidDebt(又名@Amount-pDebt) 我试着做那张新桌子,但有两个问题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”)在存在
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作业来运行,插入债务记录,而不是重新计算几个字段?这样,该表将始终提供帐户余额。