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

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 閱讀(776) 評論(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>
            一本一本久久| 国产一区二区欧美| 99国产精品久久久久老师 | 国产精品99久久久久久宅男| 国产精品theporn88| 国产精品www色诱视频| 男女精品视频| 欧美96在线丨欧| 欧美日韩精品免费观看视频完整| 国产日韩欧美亚洲| 国产亚洲成av人在线观看导航| 国产在线观看91精品一区| 亚洲激情一区二区| 国产亚洲激情| 久久欧美中文字幕| 亚洲国产日韩欧美在线图片| 久久香蕉国产线看观看av| 美女脱光内衣内裤视频久久网站| 亚洲大片一区二区三区| 日韩视频中午一区| 欧美成年人视频| 伊人春色精品| 欧美一区二区在线| 亚洲中午字幕| 欧美性生交xxxxx久久久| 欧美一区综合| 免费在线播放第一区高清av| 欧美高清在线| 国产精品久久国产愉拍| 国产一区二区高清视频| 亚洲欧洲视频| 久久精品视频免费| 日韩一区二区精品| 欧美日韩精品三区| 一区二区三区高清不卡| 午夜日本精品| 国产午夜精品久久久久久免费视| 日韩视频久久| 米奇777超碰欧美日韩亚洲| 一区二区三区欧美日韩| 蘑菇福利视频一区播放| 国产精品久久精品日日| 国产精品美女久久久久久久| 久久精品久久综合| 国产真实乱子伦精品视频| 亚洲免费伊人电影在线观看av| 久久婷婷久久一区二区三区| 亚洲视频狠狠| 国产九九视频一区二区三区| 国产精品白丝jk黑袜喷水| 老司机精品福利视频| 国产精品视屏| 亚洲手机在线| 亚洲精品综合精品自拍| 另类av导航| 伊人精品成人久久综合软件| 久久99伊人| 亚洲影院在线| 国产精品一级二级三级| 亚洲主播在线| 亚洲最新视频在线| 亚洲综合三区| 欧美成人一品| 亚洲视屏在线播放| 欧美日韩精品综合在线| 一本综合精品| 亚洲成人资源网| 久久久91精品国产| 久久婷婷亚洲| 亚洲一区二区av电影| 亚洲精品少妇| 欧美亚洲三区| 亚洲一区图片| 国产美女一区二区| 欧美在线亚洲在线| 欧美怡红院视频一区二区三区| 国产一区二区高清不卡| 性视频1819p久久| 久久不见久久见免费视频1| 亚洲激情在线观看| 亚洲欧美成人网| 亚洲人精品午夜| 亚洲欧美一区二区三区久久| 亚洲欧洲日本在线| 午夜精品久久| 亚洲视频久久| 久久夜色精品国产欧美乱| 亚洲欧美日韩中文视频| 午夜欧美大片免费观看| 国产精品丝袜91| 在线观看日韩国产| 亚洲愉拍自拍另类高清精品| 国产欧美日韩视频在线观看| 久久综合狠狠综合久久综合88| 欧美日韩亚洲一区| 亚洲一区二区三区四区五区黄| 亚洲免费高清| 亚洲国产成人在线播放| 午夜视频久久久| 亚洲专区一区二区三区| 欧美a级片一区| 久久综合九色综合欧美就去吻| 欧美午夜视频网站| 亚洲七七久久综合桃花剧情介绍| 韩国av一区二区三区在线观看| 亚洲午夜高清视频| 中文精品99久久国产香蕉| 你懂的视频一区二区| 久久综合网络一区二区| 国产色爱av资源综合区| 亚洲女同同性videoxma| 欧美一级播放| 国产精品一区二区三区观看| 欧美国产1区2区| 国产精品一区在线观看| 亚洲毛片在线观看| 久久成人资源| 亚洲国产精品成人| 欧美日韩精品一区二区| 91久久精品国产91性色| 亚洲靠逼com| 欧美日韩国产高清视频| 亚洲免费不卡| 亚洲嫩草精品久久| 亚洲中字在线| 久久精品视频99| 国产日韩欧美精品在线| 欧美一级大片在线免费观看| 久久精品噜噜噜成人av农村| 国产综合视频| 亚洲欧美另类久久久精品2019| 欧美中文字幕精品| 狠狠久久亚洲欧美| 免费日本视频一区| 亚洲乱码一区二区| 欧美亚洲综合在线| 亚洲电影免费观看高清| 欧美激情第3页| 一本色道精品久久一区二区三区| 亚洲欧美国产视频| 国内精品福利| 媚黑女一区二区| 亚洲精品久久久久久久久久久久久| 99视频超级精品| 欧美成人国产va精品日本一级| 一本不卡影院| 欧美高清自拍一区| 欧美在线不卡视频| 国产欧美69| 毛片基地黄久久久久久天堂| 日韩图片一区| 久久久久久久久岛国免费| 亚洲欧洲在线免费| 国产精品一卡| 99在线|亚洲一区二区| 久久精品天堂| 亚洲国产精品久久久久婷婷884 | 久久五月婷婷丁香社区| 欧美激情1区2区| 亚洲一区二区黄| 激情视频一区二区| 免费在线观看精品| 亚洲天堂免费在线观看视频| 久久久免费av| 日韩写真视频在线观看| 国产精品视频久久久| 久久影视精品| 日韩小视频在线观看专区| 久久精品免费观看| 一本色道久久88综合日韩精品| 国产精品嫩草影院一区二区| 久久久欧美一区二区| 在线一区二区三区做爰视频网站| 久久综合一区| 欧美亚洲网站| 亚洲美女视频在线免费观看| 国产一区二区日韩| 牛牛影视久久网| 久久国产高清| 亚洲国产天堂久久国产91| 久久精品人人做人人综合| 亚洲一线二线三线久久久| 黄色亚洲网站| 国产视频观看一区| 国产精品国产三级国产aⅴ无密码| 蜜桃精品久久久久久久免费影院| 亚洲欧美日韩国产一区二区| 亚洲免费观看高清完整版在线观看| 美国十次了思思久久精品导航| 欧美在线视频观看| 午夜久久tv| 亚洲午夜精品一区二区| 国产亚洲一区二区三区在线播放| 亚洲韩日在线| 欧美在线观看你懂的| 久久久久成人网| 久久久精品tv| 久久精品成人一区二区三区| 亚洲一区二区在| 亚洲永久免费观看|