0

さて、問題の全体的な範囲は、テーブル値関数を使用しているため、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
4

1 に答える 1

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))
于 2013-09-05T15:29:22.383 に答える