簡體   English   中英

使用if語句如何替換值

[英]using if statement how to replace values

我有兩張桌子

數據庫1:

表格1:

  • ID -001(INT)

  • 名稱-xxx(varchar)

  • 男性-0(位)

  • 女1(位)

數據庫2:

表2:

  • ID -1(INT)

  • Ca.Name-yyy(varchar)

  • 性別-M或F(varchar)

這些是我的桌子。 我想將數據從數據庫2,表2更新到數據庫1,表1。 所以我創建更新查詢。 但是我對性別領域有疑問

Select 'UPDATE T1
 SET T1.MALE ='+ CASE WHEN r.Gender = 'M' THEN 0 ELSE 1 END

 FROM T2 As r

在下面的代碼中,我給我加了星標的我懷疑如何在此處使用if語句。 有人知道可以解決我的問題嗎?

為此使用case when

遵循這個問題:

SQL Server:CASE WHEN OR THEN ELSE END =>不支持OR

CASE  
  WHEN GENDER='M' THEN 0 
  ELSE 1 
END 

這可以在您的情況下。

有關更多語法詳細信息: CASE(Transact-SQL)

同樣,您需要使用CASE WHEN 查詢如下所示:

UPDATE T1 
SET T1.MALE = CASE WHEN T2.caname = 'm' THEN 0 ELSE 1 END,
    T1.female = CASE WHEN T2.caname = 'm' THEN 1 ELSE 0 END  // you also need update this otherwise a person would end up with two genders :)
FROM TABLE1 T1
INNER JOIN table2 T2 ON T2.ID = T1.ID

SQL內容演示:

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM