好的,所以问题的总体范围是我正在使用表值函数,因此 SSRS 可以根据数据创建各种报告,然后我使用另一个程序将所有这些报告拼接在一起。所以无论如何,问题是如果该行中的另一列包含某个值,我需要获取该列的值。然后在将该值添加到另一个地方后,将一个新值放回数据库行的列中,以便其他报告和使用该数据。例如:
RETURNS @ReportTable table
(
str_beta_group varchar(64) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,
str_alpha_group varchar(64) COLLATE SQL_Latin1_General_CP1_CI_AS NULL,
str_group varchar(64) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,
debit decimal(24, 6) NULL,
credit decimal(24, 6) NULL,
credit_total decimal(24,6) NULL
)
我是数据库开发的新手,我尝试了各种方法,但我无法弄清楚如何让语法正确,而且我总是以错误告终。因此,根据上表,我将如何使用 T-Sql 语法编写此逻辑:
decimal epsilon_temp, gamma_temp;
if(str_group='epsilon')
{
epsilon_temp = credit; --the credit from that row where str_group = epsilon
}
else if(str_group='gamma')
{
gamma_temp = credit; --the credit from that row where str_group = gamma
}
--Then after that UPDATE
UPDATE @ReportTable
SET credit_total = SUM(epsilon_temp + gamma_temp )
WHERE str_group = epsilon