青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

SQL使用記錄

問題:Update字段來自子查詢或者來自其他表字段

Update 語句

Update 語句用于修改表中的數據。

語法:

UPDATE 表名稱 SET 列名稱 = 新值 WHERE 列名稱 = 某值
SQL update select語句
最常用的update語法是:
UPDATE <table_name> SET <column_name1> = <value>, SET <column_name2> = <value>
如果我的更新值Value是從一條select語句拿出來,而且有很多列的話,用這種語法就很麻煩
第一,要select出來放在臨時變量上,有很多個哦
第二,再將變量進行賦值。
列多起來非常麻煩,能不能像Insert那樣,把整個Select語句的結果進行插入呢?就好象下面
insert into table1 (c1, c2, c3) (select v1, v2, v3 from table2)
 
答案是可以的,具體的語法如下:
UPDATE <table_name> <alias>
SET (<column_name>,<column_name> ) = (
SELECT (<column_name>, <column_name>)
FROM <table_name>
WHERE <alias.column_name> = <alias.column_name>)
WHERE <column_name> <condition> <value>;
 
下面是這樣一個例子:
兩個表a、b,想使b中的memo字段值等于a表中對應id的name值 
表a:id, name 
1 王 
2 李 
3 張 
表b:id,ClientName   
            1 
(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 語句格式
當where和set都需要關聯一個表進行查詢時,整個update執行時,就需要對被關聯的表進行兩次掃描,顯然效率比較低。
對于這種情況,Sybase和SQL SERVER的解決辦法是使用UPDATE...SET...FROM...WHERE...的語法,實際上就是從源表獲取更新數據。
 
在 SQL 中,表連接(left join、right join、inner join 等)常常用于 select 語句,其實在 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
用來同步兩個表的數據!
 
Oralce和DB2都支持的語法:
UPDATE A SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)
MS SQL Server不支持這樣的語法,相對應的寫法為:
UPDATE A  SET A1 = B1, A2 = B2, A3 = B3  FROM A LEFT JOIN B ON A.ID = B.ID
個人感覺MS SQL Server的Update語法功能更為強大。MS SQL SERVER的寫法:
UPDATE A SET A1 = B1, A2 = B2, A3 = B3 FROM A, B WHERE A.ID = B.ID
OracleDB2中的寫法就比較麻煩了,如下:
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)


但對于MySql以上卻不行

Single-table語法:

UPDATE [LOW_PRIORITY] [IGNORE] tbl_name
    SET col_name1=expr1 [, col_name2=expr2 ...]
    [WHERE where_definition]
    [ORDER BY ...]
    [LIMIT row_count]

Multiple-table語法:

UPDATE [LOW_PRIORITY] [IGNORE] table_references
    SET col_name1=expr1 [, col_name2=expr2 ...]
    [WHERE where_definition]

UPDATE語法可以用新值更新原有表行中的各列。SET子句指示要修改哪些列和要給予哪些值。WHERE子句指定應更新哪些行。如果沒有WHERE子句,則更新所有的行。如果指定了ORDER BY子句,則按照被指定的順序對行進行更新。LIMIT子句用于給定一個限值,限制可以被更新的行的數目。

 

如果您在一個表達式中通過tbl_name訪問一列,則UPDATE使用列中的當前值。例如,以下語句把年齡列設置為比當前值多一:

UPDATE persondata SET age=age+1;

UPDATE賦值被從左到右評估。例如,以下語句對年齡列加倍,然后再進行增加:

UPDATE persondata SET age=age*2, age=age+1;

如果您把一列設置為其當前含有的值,則MySQL會注意到這一點,但不會更新。

update表的某些字段為null

update person set number=null,name=null;

如果您把被已定義為NOT NULL的列更新為NULL,則該列被設置到與列類型對應的默認值,并且累加警告數。對于數字類型,默認值為0;對于字符串類型,默認值為空字符串('');對于日期和時間類型,默認值為“zero”值。

 

多個表的UPDATE操作

UPDATE items,month SET items.price=month.price WHERE items.id=month.id;

以上的例子顯示出了使用逗號操作符的內部聯合,但是multiple-table UPDATE語句可以使用在SELECT語句中允許的任何類型的聯合,比如LEFT JOIN,但是您不能把ORDER BYLIMITmultiple-table UPDATE同時使用。

MYSQL聯合多表更新和刪除
多表更新
在 MySQL 3.23 中,你可以使用 LIMIT # 來確保只有給定的記錄行數目被更改。 

如果一個 ORDER BY 子句被使用(從 MySQL 4.0.0 開始支持),記錄行將以指定的次序被更新。這實際上只有連同 LIMIT 一起才有用。 

從 MySQL 4.0.4 開始,你也可以執行一個包含多個表的 UPDATE 的操作: 

UPDATE items,month SET items.price=month.price
WHERE items.id=month.id;

注意:多表 UPDATE 不可以使用 ORDER BY 或 LIMIT。 


多表刪除
第一個多表刪除格式從 MySQL 4.0.0 開始被支持。第二個多表刪除格式從 MySQL 4.0.2 開始被支持。 

僅僅在 FROM 或 USING 子句 之前 列出的表中的匹配記錄行被刪除。效果就是,你要以從多個表中同時刪除記錄行,并且同樣可以有其它的表用于檢索。 

在表名后的 .* 僅僅是為了兼容 Access: 

DELETE t1,t2 FROM t1,t2,t3 WHERE t1.id=t2.id AND t2.id=t3.id   or    DELETE FROM t1,t2 USING t1,t2,t3 WHERE t1.id=t2.id AND t2.id=t3.id

在上面的情況下,我們僅僅從 t1 和 t2 表中刪除匹配的記錄行。 

如果一個 ORDER BY 子句被使用(從 MySQL 4.0.0 開始支持), 記錄行將以指定的次序刪除。這實際上只有連同 LIMIT 一起才有用。示例如下: 

DELETE FROM somelog  WHERE user = 'jcole'  ORDER BY timestamp LIMIT 1

這將刪除匹配 WHERE 子句的,并且最早被插入(通過 timestamp 來確定)的記錄行。 

DELETE 語句的LIMIT rows 選項是 MySQL 特有的,它告訴服務器在控制權被返回到客戶端之前可被刪除的最大記錄行數目。這可以用來確保一個特定的 DELETE 命令不會占用太長的時間。你可以簡單地重復使用 DELETE 命令,直到被影響的記錄行數目小于 LIMIT 值。 

從 MySQL 4.0 開始,在 DELETE 語句中可以指定多個表,用以從一個表中刪除依賴于多表中的特殊情況的記錄行。然而,在一個多表刪除中,不能使用 ORDER BY 或 LIMIT。
假設有兩個表,tab1,tab2,分別有產品名稱和產品價格,現在我想用tab2的價格替換tab1的價格,我寫的語句是Update tab1 set tab1.產品價格=tab2.產品價格 where tab1.產品名稱=tab2.產品名稱 
結果出現錯誤,提示為:列前綴 'tab2' 與查詢中所用的表名或別名不匹配。請問應該怎樣寫,

SQL語句是不支持多表同時更新的。 

應該這樣寫 

update tab1 set tab1.產品價格 = (select tab2.產品價格 from tab2 where tab2.產品名稱 = tab1.產品名稱) where tabl1.產品名稱 in (select tab2.產品名稱 from tab2) 


后面的where tab1.產品名稱 in (select tab2.產品名稱 from tab2) 這句保證了如果tab1的產品在tab2沒有記錄時不會出錯。


在 開發中,數據庫來回換,而有些關鍵性的語法又各不相同,這是一件讓開發人員很頭痛的事情.本文總結了Update語句更新多表時在SQL Server,Oracle,MySQL三種數據庫中的用法.我也試了SQLite數據庫,都沒成功,不知是不支持多表更新還是咋的. 

在本例中: 

我們要用表gdqlpj中的gqdltks,bztks字段數據去更新landleveldata中的同字段名的數據,條件是當landleveldata 中的GEO_Code字段值與gdqlpj中的lxqdm字段值相等時進行更新. 

SQL Server語法: 
UPDATE 
          { 
           table_name WITH ( < table_hint_limited > [ ...n ] ) 
           | view_name 
           | rowset_function_limited 
          } 
          SET 
          { column_name = { expression | DEFAULT | NULL } 
          | @variable = expression 
          | @variable = column = expression } [ ,...n ] 

      { { [ FROM { < table_source > } [ ,...n ] ] 

          [ WHERE 
              < search_condition > ] } 
          | 
          [ WHERE CURRENT OF 
          { { [ GLOBAL ] cursor_name } | cursor_variable_name } 
          ] } 
          [ OPTION ( < query_hint > [ ,...n ] ) ] 

SQL Server示例: 
update a 
set a.gqdltks=b.gqdltks,a.bztks=b.bztks 
from landleveldata a,gdqlpj b 
where a.GEO_Code=b.lxqdm 

Oracle語法: 
UPDATE    updatedtable 
      SET (col_name1[,col_name2...])= 
(SELECT    col_name1,[,col_name2...]   
FROM    srctable [WHERE where_definition]) 

Oracel 示例: 
update landleveldata a 
set (a.gqdltks, a.bztks)= 
(select b.gqdltks, b.bztks    from gdqlpj b 
    where a.GEO_Code=b.lxqdm) 

MySQL語法: 
UPDATE table_references 
      SET col_name1=expr1 [, col_name2=expr2 ...] 
      [WHERE where_definition] 

MySQL 示例: 
update landleveldata a, gdqlpj b 
set a.gqdltks= b.gqdltks, 
a.bztks= b.bztks 
    where a.GEO_Code=b.lxqdm

MySQL SELECT同時UPDATE同一張表
MySQL不允許SELECT FROM后面指向用作UPDATE的表,有時候讓人糾結。當然,有比創建無休止的臨時表更好的辦法。本文解釋如何UPDATE一張表,同時在查詢子句中使用SELECT.

問題描述

假設我要UPDATE的表跟查詢子句是同一張表,這樣做有許多種原因,例如用統計數據更新表的字段(此時需要用group子句返回統計值),從某一條記錄的字段update另一條記錄,而不必使用非標準的語句,等等。舉個例子:
  1. create table apples(variety char(10) primary key, price int);  
  2.   
  3. insert into apples values('fuji', 5), ('gala', 6);  
  4.   
  5. update apples  
  6.     set price = (select price from apples where variety = 'gala')  
  7.     where variety = 'fuji';  

錯誤提示是:ERROR 1093 (HY000): You can't specify target table 'apples' for update in FROM clause. MySQL手冊UPDATE documentation這下面有說明 : “Currently, you cannot update a table and select from the same table in a subquery.”
在這個例子中,要解決問題也十分簡單,但有時候不得不通過查詢子句來update目標。好在我們有辦法。

解決辦法

既然MySQL是通過臨時表來實現FROM子句里面的嵌套查詢,那么把嵌套查詢裝進另外一個嵌套查詢里,可使FROM子句查詢和保存都是在臨時表里進行,然后間接地在外圍查詢被引用。下面的語句是正確的:
  1. update apples  
  2.    set price = (  
  3.       select price from (  
  4.          select * from apples  
  5.       ) as x  
  6.       where variety = 'gala')  
  7.    where variety = 'fuji';  

如果你想了解更多其中的機制,請閱讀MySQL Internals Manual相關章節。

沒有解決的問題

一個常見的問題是,IN()子句優化廢品,被重寫成相關的嵌套查詢,有時(往往?)造成性能低下。把嵌套查詢裝進另外一個嵌套查詢里并不能阻止它重寫成相關嵌套,除非我下狠招。這種情況下,最好用JOIN重構查詢(rewrite such a query as a join)。

另一個沒解決的問題是臨時表被引用多次。“裝進嵌套查詢”的技巧無法解決這些問題,因為它們在編譯時被創建,而上面討論的update問題是在運行時。(譯者注:個人認為跟文章討論的主題沒幾毛錢關系)

轉載請注明出處 http://blog.csdn.net/afeiqiang/article/details/8589535

原文地址 http://www.xaprb.com/blog/2006/06/23/how-to-select-from-an-update-target-in-mysql/

posted on 2015-03-17 15:43 Daywei 閱讀(777) 評論(0)  編輯 收藏 引用 所屬分類: DB

<2015年3月>
22232425262728
1234567
891011121314
15161718192021
22232425262728
2930311234

導航

統計

常用鏈接

留言簿

隨筆分類

隨筆檔案

文章檔案

牛人博客

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品普通话对白| 理论片一区二区在线| 欧美日韩国产在线| 一本色道久久综合亚洲精品高清| 亚洲国产欧美日韩| 欧美成人精品h版在线观看| 亚洲日本va午夜在线电影| 亚洲黄一区二区| 欧美性大战久久久久| 欧美影院久久久| 久久婷婷激情| 在线一区二区三区四区五区| 亚洲一区二区在线播放| 国内精品写真在线观看| 亚洲国产成人91精品| 国产精品家庭影院| 久久综合一区二区| 欧美日韩成人综合在线一区二区| 亚洲男同1069视频| 久久―日本道色综合久久| 一区二区三区国产在线| 亚洲欧美日韩专区| 91久久线看在观草草青青| 亚洲视频香蕉人妖| 亚洲国产成人在线播放| 在线亚洲国产精品网站| 亚洲二区精品| 99爱精品视频| 亚洲第一精品电影| 亚洲婷婷综合色高清在线| 亚洲大片av| 亚洲欧美国产制服动漫| 亚洲人成人一区二区在线观看| 亚洲性夜色噜噜噜7777| 亚洲精品国产拍免费91在线| 性欧美xxxx视频在线观看| 日韩视频在线永久播放| 久久久999精品免费| 亚洲一区二区三区中文字幕| 开心色5月久久精品| 久久99伊人| 国产精品国产三级国产普通话三级| 蜜桃av一区二区| 国产无一区二区| 亚洲天堂第二页| 一本到高清视频免费精品| 蜜桃av噜噜一区| 久久人人97超碰国产公开结果| 欧美日韩在线综合| 亚洲人成亚洲人成在线观看| 亚洲第一中文字幕| 久久精品亚洲精品国产欧美kt∨| 午夜精品久久久久久久99黑人| 欧美另类在线观看| 亚洲国产综合视频在线观看| 亚洲大胆视频| 欧美大片在线观看一区| 亚洲国产mv| 日韩视频在线一区二区| 欧美另类综合| 亚洲精品乱码久久久久久蜜桃91| 在线日韩精品视频| 久久影音先锋| 男人的天堂亚洲在线| 在线日韩av片| 乱人伦精品视频在线观看| 欧美成黄导航| 亚洲欧美日本国产有色| 亚洲欧美日韩一区| 国产日韩欧美精品在线| 午夜在线不卡| 牛人盗摄一区二区三区视频| 亚洲国产精品久久精品怡红院| 久久se精品一区精品二区| 久久久久久尹人网香蕉| 在线不卡中文字幕播放| 麻豆91精品| 亚洲精品五月天| 亚洲欧美韩国| 国语精品中文字幕| 免费久久99精品国产自在现线| 亚洲第一色在线| 99视频精品免费观看| 国产精品美女久久久久久免费 | 日韩一区二区福利| 欧美日韩日日夜夜| 亚洲欧美综合国产精品一区| 毛片av中文字幕一区二区| 亚洲精品一区在线观看香蕉| 欧美三级电影精品| 欧美专区第一页| 91久久国产综合久久| 亚洲一区二区视频| 99视频有精品| 在线激情影院一区| 欧美日本一区二区三区| 亚洲免费人成在线视频观看| 美日韩免费视频| 一区二区三区视频在线| 国产专区欧美专区| 欧美日韩高清在线| 久久av红桃一区二区小说| 亚洲精品在线观| 久久夜色精品国产亚洲aⅴ| 99re在线精品| 伊人激情综合| 国产精品捆绑调教| 欧美成人久久| 欧美一区2区三区4区公司二百| 亚洲电影免费观看高清完整版在线观看 | 激情久久久久久久| 欧美视频一区在线| 美女主播一区| 久久国产99| 一本大道久久精品懂色aⅴ| 美女精品视频一区| 欧美综合国产| 亚洲欧美大片| 一区二区三区日韩在线观看| 精品成人国产在线观看男人呻吟| 欧美特黄视频| 欧美国产精品日韩| 久久久亚洲高清| 午夜宅男欧美| 亚洲亚洲精品三区日韩精品在线视频 | 亚洲日本理论电影| 激情综合在线| 国产在线精品成人一区二区三区 | 欧美日韩精品免费观看| 麻豆成人综合网| 久久久久网站| 久久久999| 久久久久久一区| 久久精品女人的天堂av| 欧美一区视频| 欧美一区二区三区免费视| 亚洲一区二区在线免费观看| 99视频超级精品| 99国产精品久久久久久久久久| 亚洲激情小视频| 亚洲日本中文字幕| 亚洲日本激情| 一二三四社区欧美黄| 日韩视频专区| 亚洲一区二区三区高清| 亚洲一区在线视频| 亚洲影院色在线观看免费| 亚洲砖区区免费| 久久国产精彩视频| 久久午夜精品一区二区| 久热精品视频在线观看| 欧美成人综合网站| 欧美日韩国内自拍| 国产精品豆花视频| 国产日韩欧美亚洲一区| 一区二区三区自拍| 91久久精品网| 亚洲欧美日韩国产成人精品影院 | 亚洲午夜小视频| 亚洲最新视频在线| 免费看黄裸体一级大秀欧美| 牛牛影视久久网| 亚洲免费福利视频| 午夜精品久久久久久久99热浪潮 | 国产一区二区视频在线观看| 精品成人久久| 一本一本久久| 欧美在线视频观看免费网站| 久久青草久久| 亚洲精品在线免费| 亚洲欧美日韩天堂| 美女精品自拍一二三四| 欧美色视频在线| 狠色狠色综合久久| 在线亚洲美日韩| 久久男女视频| 99伊人成综合| 久久一区二区三区超碰国产精品 | 午夜在线a亚洲v天堂网2018| 欧美成人网在线| 国产亚洲欧洲一区高清在线观看| 亚洲国产毛片完整版| 亚洲欧美一区二区三区极速播放 | 欧美一区二区三区视频免费| 欧美插天视频在线播放| 亚洲欧美日韩中文播放| 欧美另类一区| 亚洲风情亚aⅴ在线发布| 亚洲欧美日韩国产成人精品影院| 欧美sm视频| 午夜精品久久久久久久99樱桃| 久久综合久久综合久久| 国产欧美韩日| 亚洲先锋成人| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲国产天堂久久综合网| 午夜影视日本亚洲欧洲精品| 欧美日韩亚洲一区二区| 在线精品一区| 久久在线免费|