gpt4 book ai didi

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

转载 作者:搜寻专家 更新时间:2023-10-30 23:42:51 31 4
gpt4 key购买 nike

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

2013年之前的旧债是6万,后来变成了7.5万

我在程序中还有一个“事件”列,如果该成员仍然活跃,则设置为"is",如果他停止,则更改为“否”还有另一个名为“pDebt”的列,代表已付债务

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

我试着制作那个新 table ,但我遇到了两个问题

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

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

  2. 我无法将我的 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)

对不起,我知道我没有正确输入代码的结尾(最后一行说@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

关于sql-server - SQL Server 使用 WHILE 循环添加计算列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32954185/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com