字體:
大
中
小 發(fā)表日期:2007-07-31 10:19 評論:0 點擊:3262
關(guān)于使用多表做update的語法
===========================================================
一、當(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)

:D