如果满足特定条件,则从一行获取信息

时间:2013-09-05 13:19:33

标签: sql sql-server-2008 tsql ssrs-2008 table-valued-parameters

好的,问题的整体范围是我正在使用表值函数,因此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

1 个答案:

答案 0 :(得分:0)

我正在猜测你需要什么。这是关于如何从数据中获得总和并通过str_group对结果进行分组?这看起来如何:

SELECT
  CASE WHEN str_group is NULL THEN 'TOTAL' ELSE str_group END str_group
  SUM(credit) credit
FROM 
  table
GROUP BY GROUPING SETS 
  ((),(str_group))
相关问题