Получить информацию из строки, если она соответствует определенным критериям

Итак, общий объем проблемы заключается в том, что я использую функцию с табличным значением, поэтому 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

person Mickey Sly    schedule 05.09.2013    source источник


Ответы (1)


Я догадываюсь, что Вам нужно. Это о том, как получить суммы из данных и сгруппировать результаты по 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))
person Der U    schedule 05.09.2013
comment
Спасибо за ваш ответ. Тем не менее, это не совсем то, что я искал. Я думаю, может быть, я объяснил это немного громоздко. Так что я попытаюсь объяснить это лучше сейчас. Одна строка в приведенной выше таблице будет иметь столбец для str_beta_group,str_alpha_group,str_group,debit,credit и credit_total...извините, случайно нажала на ввод. - person Mickey Sly; 05.09.2013