今天遇到一個問題,就是在原來的一個表的基礎(chǔ)上增加兩個字段,并且根據(jù)歷史數(shù)據(jù)和一個計算方法把這兩個字段補(bǔ)齊。
到網(wǎng)上查了一下。
一、當(dāng)用一個表中的數(shù)據(jù)來更新另一個表中的數(shù)據(jù),T-SQL提供多種寫法(下面列出了二種),但建議用第一種寫法,雖然傳統(tǒng),但結(jié)構(gòu)清晰。
并且要注意,當(dāng)用一個表中的數(shù)據(jù)來更新另一個表中的數(shù)據(jù)時,二個表一定要有關(guān)聯(lián)!
1.
update t1
set t1.c2 = t2.c2
from t2
where t1.c1 = t2.c1
2.
Update t1
set t1.c2 = t2.c2
from t1 inner join t2
on t1.c1 = t2.c1
二、FROM 子句中指定的表的別名不能作為 SET column_name 子句中被修改字段的限定符使用。
例如,下面的內(nèi)容無效:
UPDATE titles
SET t.ytd_sales = t.ytd_sales + s.qty
FROM titles t, sales s
WHERE t.title_id = s.title_id
AND s.ord_date = (SELECT MAX(sales.ord_date) FROM sales)
若要使上例合法,請從列名中刪除別名 t 或使用本身的表名。
1.
UPDATE titles
SET ytd_sales = t.ytd_sales + s.qty
FROM titles t, sales s
WHERE t.title_id = s.title_id
AND s.ord_date = (SELECT MAX(sales.ord_date) FROM sales)
2.
UPDATE titles
SET titles.ytd_sales = t.ytd_sales + s.qty
FROM titles t, sales s
WHERE t.title_id = s.title_id
AND s.ord_date = (SELECT MAX(sales.ord_date) FROM sales)
posted on 2011-03-31 18:28
漂漂 閱讀(3000)
評論(0) 編輯 收藏 引用