午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    SQL update select
    來源:易賢網(wǎng) 閱讀:1495 次 日期:2014-11-03 11:48:00
    溫馨提示:易賢網(wǎng)小編為您整理了“SQL update select”,方便廣大網(wǎng)友查閱!

    最常用的update語法是:

    UPDATE

    SET = , SET =

    如果我的更新值Value是從一條select語句拿出來,而且有很多列的話,用這種語法就很麻煩

    第一,要select出來放在臨時(shí)變量上,有很多個(gè)哦

    第二,再將變量進(jìn)行賦值。

    列多起來非常麻煩,能不能像Insert那樣,把整個(gè)Select語句的結(jié)果進(jìn)行插入呢?就好象下面

    insert into table1

    (c1, c2, c3)

    (select v1, v2, v3 from table2)

    答案是可以的,具體的語法如下:

    UPDATE

    SET (, ) = (

    SELECT (, )

    FROM

    WHERE = )

    WHERE ;

    下面是這樣一個(gè)例子:

    兩個(gè)表a、b,想使b中的memo字段值等于a表中對(duì)應(yīng)id的name值

    表a:id, name

    1 王

    2 李

    3 張

    表b:id,ClientName

    1

    2

    3

    (MS SQL Server)語句:update b set ClientName = a.name from a,b where a.id = b.id

    (Oralce)語句:update b set (ClientName) = (SELECT name FROM a WHERE b.id = a.id)

    update set from 語句格式

    當(dāng)where和set都需要關(guān)聯(lián)一個(gè)表進(jìn)行查詢時(shí),整個(gè)update執(zhí)行時(shí),就需要對(duì)被關(guān)聯(lián)的表進(jìn)行兩次掃描,顯然效率比較低。

    對(duì)于這種情況,Sybase和SQL SERVER的解決辦法是使用UPDATE...SET...FROM...WHERE...的語法,實(shí)際上就是從源表獲取更新數(shù)據(jù)。

    在 SQL 中,表連接(left join、right join、inner join 等)常常用于 select 語句,其實(shí)在 SQL 語法中,這些連接也是可以用于 update 和 delete 語句的,在這些語句中使用 join 還常常得到事半功倍的效果。

    Update T_OrderForm SET T_OrderForm.SellerID =B.L_TUserID

    FROM T_OrderForm A LEFT JOIN T_ProductInfo B ON B.L_ID=A.ProductID

    用來同步兩個(gè)表的數(shù)據(jù)!

    Oralce和DB2都支持的語法:

    UPDATE A SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)

    MS SQL Server不支持這樣的語法,相對(duì)應(yīng)的寫法為:

    UPDATE A SET A1 = B1, A2 = B2, A3 = B3 FROM A LEFT JOIN B ON A.ID = B.ID

    個(gè)人感覺MS SQL Server的Update語法功能更為強(qiáng)大。MS SQL SERVER的寫法:

    UPDATE A SET A1 = B1, A2 = B2, A3 = B3 FROM A, B WHERE A.ID = B.ID

    在Oracle和DB2中的寫法就比較麻煩了,如下:

    UPDATE A SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)

    WHERE ID IN (SELECT B.ID FROM B WHERE A.ID = B.ID)

    更多信息請(qǐng)查看IT技術(shù)專欄

    更多信息請(qǐng)查看數(shù)據(jù)庫(kù)
    易賢網(wǎng)手機(jī)網(wǎng)站地址:SQL update select
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2025國(guó)考·省考課程試聽報(bào)名

    • 報(bào)班類型
    • 姓名
    • 手機(jī)號(hào)
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
    云南網(wǎng)警備案專用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專用圖標(biāo)