これらの行があるテーブルEmp
があります。
Emp_cd | Val1 | Val2 | Val3 | Total
-------+-------+-------+-------+-------
1 | 1.23 | 2.23 | 3.43 |
2 | 23.03 | 12.23 | 2.92 |
3 | 7.23 | 9.05 | 13.43 |
4 | 03.21 | 78.23 | 9.43 |
Val1, Val2, Val3
のSUM
を見つけたいのですが、Total
列に表示されます。
簡単:
SELECT
Val1,
Val2,
Val3,
(Val1 + Val2 + Val3) as 'Total'
FROM Emp
または、1行だけが必要な場合:
SELECT
SUM(Val1) as 'Val1',
SUM(Val2) as 'Val2',
SUM(Val3) as 'Val3',
(SUM(Val1) + SUM(Val2) + SUM(Val3)) as 'Total'
FROM Emp
null
レコードにも注意する必要があります。
SELECT (ISNULL(Val1,0) + ISNULL(Val2,0) + ISNULL(Val3,0)) as 'Total'
FROM Emp
ISNULL
の使用法:
ISNULL(col_Name, replace value)
通常のSELECT
と同じですか?
SELECT
Val1, Val2, Val3,
Total = Val1 + Val2 + Val3
FROM dbo.Emp
または、その合計を決定し、それらの値でテーブルを更新しますか?
UPDATE dbo.Emp
SET Total = Val1 + Val2 + Val3
この合計を常に最新にしたい場合は、テーブルに計算列が必要です。
ALTER TABLE dbo.Emp
ADD CurrentTotal AS Val1 + Val2 + Val3 PERSISTED
次に、always現在の合計を取得します-値が変わっても:
SELECT
Val1, Val2, Val3, CurrentTotal
FROM dbo.Emp
これを試して:
select sum(num_tax_amount+num_total_amount) from table_name;
COALESCEを使用した別の例。 http://sqlmag.com/t-sql/coalesce-vs-isnull
SELECT (COALESCE(SUM(val1),0) + COALESCE(SUM(val2), 0)
+ COALESCE(SUM(val3), 0) + COALESCE(SUM(val4), 0)) AS 'TOTAL'
FROM Emp
こんにちは、簡単なクエリを使用できます。
select emp_cd, val1, val2, val3,
(val1+val2+val3) as total
from emp;
新しい行を挿入する必要がある場合、
insert into emp select emp_cd, val1, val2, val3,
(val1+val2+val3) as total
from emp;
更新するには、
update emp set total = val1+val2+val3;
これはすべてのcomumnsのために更新されます