Caseステートメントを使用してテーブルを更新したいのですが、クエリは次のようになります...
select case(@columnname) when 'name1' then
begin
update table
set
pay1=pay1* 100
pay2=pay2*20
pay3=pay3* 100
end
when 'name2' then
begin
update table
set
pay2=pay2*20
pay3=pay3* 100
end
when 'name3' then
begin
update table
set
pay3=pay3* 100
end
end
caseステートメントを使用してクエリを完了するための正しいロジックを教えてください
構文を入れ替える必要があります。 caseステートメントは、更新するすべての値に適用されます...
UPDATE table SET
pay1 = CASE WHEN @columnname IN('name1') THEN pay1 * 100 ELSE pay1 END,
pay2 = CASE WHEN @columnname IN('name1', 'name2') THEN pay2 * 20 ELSE pay2 END,
pay3 = CASE WHEN @columnname IN('name1', 'name2', 'name3') THEN pay3 * 100 ELSE pay3 END
実際に必要なのはifステートメントのようです。
IF @columnname = 'name1'
UPDATE table SET pay1 = pay1 * 100, pay2=pay2*20, pay3=pay3* 100
ELSE IF @ColumnName = 'name2'
UPDATE table SET pay2 = pay2 * 20, pay3 = pay3 * 100
ELSE IF @ColumnName = 'name3'
UPDATE table SET pay3 = pay3 * 100
それが役立つことを願っています
これを使って。
update table
set pay1 = CASE WHEN @columnname = 'name1'
THEN pay1* 100
ELSE pay1
set pay2 = CASE WHEN @columnname = 'name1'
OR @columnname = 'name2'
THEN pay2* 20
ELSE pay2
set pay3 = CASE WHEN @columnname = 'name1' OR
@columnname = 'name2' OR
@columnname = 'name3'
THEN pay3 * 100
ELSE pay3
あなたはこのようなものを使うことができます:
UPDATE DBO.Test1
SET val1=
CASE name
WHEN 'name1' THEN val1*100
ELSE val1
END,
val2=
CASE name
WHEN 'name1' THEN val2*20
WHEN 'name2' THEN val2*20
ELSE val2
END,
val3=
CASE name
WHEN 'name1' THEN val3*100
WHEN 'name2' THEN val3*100
WHEN 'name3' THEN val3*100
ELSE val3
END;
Val3を更新するために異なる「When」句を使用しました。更新される値はすべての場合で同じであるため、単一の「WHEN」を使用してval3を更新できます。