MySQL數(shù)據(jù)庫之UPDATE更新語句精解_第1頁
MySQL數(shù)據(jù)庫之UPDATE更新語句精解_第2頁
MySQL數(shù)據(jù)庫之UPDATE更新語句精解_第3頁
MySQL數(shù)據(jù)庫之UPDATE更新語句精解_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、MySQ擻據(jù)庫之UPDAT匣新語句精解1 1)用于操作數(shù)據(jù)庫的SQL一般分為兩種,一種是查詢語句,也就是我們所說的SELECTS句,另外一種就是更新語句,也叫做數(shù)據(jù)操作語句。本文以MySQ師背景來討論如何使有SQL中的更新語句。一、INSERT和REPLACEINSERT和REPLAC暗句的功能都是向表中插入新的數(shù)據(jù)。這兩條語句的語法類似。它們的主要區(qū)別是如何處理重復(fù)的數(shù)據(jù)。1.INSERT的一般用法MySQL中的INSERT語句和標(biāo)準(zhǔn)的INSERT不太一樣,在標(biāo)準(zhǔn)的SQL語句中,一次插入一條記錄的INSERT語句只有一種形式。INSERTINTOtablename(歹U名一)VALUES(歹

2、U值);而在MySQ中還有另外一種形式。r2INSERTINTOtablenameSETcolumn_name1=value1,column_name2=value2,;第一種方法將列名和列值分開了,在使用時,列名必須和列值的數(shù)一致。如下面的語句向users表中插入了一條記錄:INSERTINTOusers(id,name,age)VALUES(123,'姚明',25);第二種方法允許列名和列值成對出現(xiàn)和使用,如下面的語句將產(chǎn)生中樣的效果。INSERTINTOusersSETid=123,name='姚明',age=25;如果使用了SET方式,必須至少為一列賦值

3、。如果某一個字段使用了省缺值(如默認(rèn)或自增值),這兩種方法都可以省略這些字段。如id字段上使用了自增值,上面兩條語句可以寫成如下形式:INSERTINTOusers(name,age)VALUES('姚明',25);INSERTINTOusesSETname='姚明',age=25;MySQLVALUES!也做了些變化。如果VALUE汕什么都不寫,那MySQLB使用表中每一列的默認(rèn)值來插入新記錄。INSERTINTOusers()VALUES();如果表名后什么都不寫,就表示向表中所有的字段賦值。使用這種方式,不僅在VALUE汕的值要和列數(shù)一致,而且順序不能顛倒

4、。INSERTINTOusersVALUES(123,'姚明',25);如果將INSERT語句寫成如下形式MySQLB會報錯。INSERTINTOusersVALUES('姚明',25);2 .使用INSERT插入多條記錄看到這個標(biāo)題也許大家會問,這有什么好說的,調(diào)用多次INSERT語句不就可以插入多條記錄了嗎!但使用這種方法要增加服務(wù)器的負(fù)荷,因為,執(zhí)行每一次SQL服務(wù)器都要同樣對SQL進(jìn)行分析、優(yōu)化等操作。幸好MySQL供了另一種解決方案,就是使用一條INSERT語句來插入多條記錄。這并不是標(biāo)準(zhǔn)的SQL語法,因此只能在MySQL中使用。INSERTINTOu

5、sers(name,age)VALUES('姚明',25),('比爾.蓋茨',50),('火星人',600);上面的INSERT語句向users表中連續(xù)插入了3條記錄。值得注意的是,上面的INSERT語句中的VALUES后必須每一條記錄的值放到一對()中,中間使用","分割。假設(shè)有一個表tablelCREATETABLEtable1(nINT);如果要向table1中插入5條記錄,下面寫法是錯誤的:INSERTINTOtable1(i)VALUES(1,2,3,4,5);MySQLM會拋出下面的錯誤IERROR1136:Col

6、umncountdoesn'tmatchvaluecountatrow1而正確的寫法應(yīng)該是這樣:INSERTINTOtable1(i)VALUES(1),(2),(3),(4),(5);當(dāng)然,這種寫法也可以省略列名,這樣每一對括號里的值的數(shù)目必須一致,而且這個數(shù)目必須和列數(shù)一致。如:INSERTINTOtable1VALUES(1),(2),(3),(4),(5);3 .REPLACE語句我們在使用數(shù)據(jù)庫時可能會經(jīng)常遇到這種情況。如果一個表在一個字段上建立了唯一索引,當(dāng)我們再向這個表中使用已經(jīng)存在的鍵值插入一條記錄,那將會拋出一個主鍵沖突的錯誤。當(dāng)然,我們可能想用新記錄的值來覆蓋原來的

7、記錄值。如果使用傳統(tǒng)的做法,必須先使用DELETE語句刪除原先的記錄,然后再使用INSERT插入新的記錄。而在MySQL中為我們提供了一種新的解決方案,這就是REPLAC斜句。使用REPLACE插入一條記錄時,如果不重復(fù),REPLACEDINSERT的功能一樣,如果有重復(fù)記錄,REPLAC僦使用新記錄的值來替換原來的記錄值。使用REPLACE勺最大好處就是可以將DELETED口INSERT合二為一,形成一個原子操作。這樣就可以不必考慮在同時使用DELET臣口INSERT時添力事務(wù)等復(fù)雜操作了。在使用REPLACED表中必須有唯一索引,而且這個索引所在的字段不能允許空值,否則REPLACED和I

8、NSERT完全一樣的。在執(zhí)行REPLACED系統(tǒng)返回了所影響的行數(shù),如果返回1,說明在表中并沒有重復(fù)的記錄,如果返回2,說明有一條重復(fù)記錄,系統(tǒng)自動先調(diào)用了DELETE刪除這條記錄,然后再記錄用INSERT來插入這條記錄。如果返回的值大于2,那說明有多個唯一索引,有多條記錄被刪除和插入。REPLACE勺語法和INSERT非常的相似,如下面的REPLAC斜句是插入或更新一條記錄。REPLACEINTOusers(id,name,age)VALUES(123,趙本山',50);插入多條記錄:REPLACEINTOusers(id,name,age)VALUES(123,'趙本山&#

9、39;,50),(134,'Mary',15);REPLACE也可以使用SET語句REPLACEINTOusersSETid=123,name='趙本山',age=50;上面曾提到REPLAC圓能影響3條以上的記錄,這是因為在表中有超過一個的唯一索引。在這種情況下,REPLAC酪考慮每一個唯一索引,并對每一個索引對應(yīng)的重復(fù)記錄都刪除,然后插入這條新記錄。假設(shè)有一個tablel表,有3個字段a,b,c。它們都有一個唯一索引。CREATETABLEtable1(aINTNOTNULLUNIQUE,bINTNOTNULLUNIQUE,cINTNOTNULLUNIQUE

10、);假設(shè)table1中已經(jīng)有了3條記錄abc1 112 223 33下面我們使用REPLAC酷句向table1中插入一條記錄。REPLACEINTOtable1(a,b,c)VALUES(1,2,3);返回的結(jié)果如下QueryOK,4rowsaffected(0.00sec)在table1中的記錄如下abc123我們可以看到,REPLAC潞原先的3條記錄都刪除了,然后將(1,2,3)插入二、UPDATEUPDATE勺功能是更新表中的數(shù)據(jù)。這的語法和INSERT的第二種用法相似。必須提供表名以及SET表達(dá)式,在后面可以加WHEREZ限制更新的記錄范圍。FnUPDATEtable_anemSETc

11、olumn_name1=value1,column_name2=value2,WHERE;如下面的語句將users表中id等于123的記錄的age改為24UPDATEusersSETage=24WHEREid=123;同樣,可以使用UPDAT哽新多個字段的值UPDATEusersSETage=24,name='Mike'WHEREid=123;上面的UPDAT曲句通過WHERE1定一個條件,否則,UPDATE各更新表中的所有記錄的值。在使用UPDAT哽新記錄時,如果被更新的字段的類型和所賦的值不匹配時,MySQLB這個值轉(zhuǎn)換為相應(yīng)類型的值。如果這個字段是數(shù)值類型,而且所賦值超過

12、了這個數(shù)據(jù)類型的最大范圍,那么MySQ就將這個值轉(zhuǎn)換為這個范圍最大或最小值。如果字符串太長,MySQ就將多余的字符串截去。如果設(shè)置非空字段為空,那么將這個字段設(shè)置為它們的默認(rèn)值,數(shù)字的默認(rèn)值是0,字符串的默認(rèn)值是空串(不是null,是與o有兩種情況UPDAT環(huán)會對影響表中的數(shù)據(jù)。1 .當(dāng)WHER中的條件在表中沒有記錄和它匹配時。2 .當(dāng)我們將同樣的值賦給某個字段時,如將字段abc賦為123',而abc的原值就是123'。和INSERTREPLAC1樣,UPDAT曲返回所更新的記錄數(shù)。但這些記錄數(shù)并不包括滿足WHER窿件的,但卻未被更新的記錄。如下同的UPDAT曲句就未更新任何記

13、錄。UPDATEusersSETage=30WHEREid=12;QueryOK,0rowsaffected(0.00sec)需要注意的時,如果一個字段的類型是TIMESTAMP那么這個字段在其它字段更新時自動更新。在有些時候我彳門需要得到UPDAT所選擇的行數(shù),而不是被更新的行數(shù)。我們可以通過一些API來達(dá)到這個目的。如MySQ牌供的CAPI提供了一個選項可以得到你想要的記錄數(shù)。而MySQL勺JDBCW動得到的默認(rèn)記錄數(shù)也是匹配的記錄數(shù)。UPDATE口REPLAC基本類似,但是它們之間有兩點不同。1. UPDATE在沒有匹配記錄時彳f么都不做,而REPLAC在有重復(fù)記錄時更新,在沒有重復(fù)記錄

14、時插入。2. UPDAT時以選擇性地更新記錄的一部分字段。而REPLAC衽發(fā)現(xiàn)有重復(fù)記錄時就將這條記錄徹底刪除,再插入新的記錄。也就是說,將所有的字段都更新了。三、DELETEDTRUNCATETABLE在MySQL中有兩種方法可以刪除數(shù)據(jù),一種是DELETED句,另一種是TRUNCATETABLE句。DELETE句可以通過WHERE要刪除的記錄進(jìn)彳亍選擇。而使用TRUNCATEABLE將刪除表中的所有記錄。因此,DELETE語句更靈活。如果要清空表中的所有記錄,可以使用下面的兩種方法:DELETEFROMtable1TRUNCATETABLEtable1其中第二條記錄中的TABLE是可選的。

15、如果要刪除表中的部分記錄,只能使用DELETED句。DELETEFROMtable1WHERE;如果DELET環(huán)加WHER子句,那么它和TRUNCATEABLE是一樣的,但它們有一點不同,那就是DELETEW以返回被刪除的記錄數(shù),而TRUNCATETABLE回的是0。如果一個表中有自增字段,使用TRUNCATETABLE沒有WHERE句的DELETE!除所有記錄后,這個自增字段將起始值恢復(fù)成1.如果你不想這樣做的話,可以在DELETE語句中加上永真的WHERE如WHERE俅WHEREtrueDELETEFROMtable1WHERE1;上面的語句在執(zhí)行時將掃描每一條記錄。但它并不比較,因為這個WHER條件永遠(yuǎn)為true。這樣做雖然可以保持自增的最大值,但由于它是掃描了所有的記錄,因此,它的執(zhí)行成本要比沒有WHERE句的DELETE大得多。DELETEDHTRUNCATETABLE最大區(qū)別是DELET時以通過WHER踣句選擇要刪除的記錄。但執(zhí)行得速度不快。而且還可以返回被刪除的記錄數(shù)。而TRUNCATEABLE無法刪除指定的記錄,而且不能返回被刪除的記錄。但它執(zhí)行得非常快。與標(biāo)準(zhǔn)的SQL語句不同,DELETE持ORDERBY口LIMIT子句,通過這兩個子句,我們可以更好地控制要刪除的記錄。如當(dāng)我們只想刪除WHERE"句過濾出來的記錄的一部分,可以使用

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論