



下載本文檔
版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、MySQ擻據(jù)庫(kù)之UPDAT匣新語(yǔ)句精解1 1)用于操作數(shù)據(jù)庫(kù)的SQL一般分為兩種,一種是查詢(xún)語(yǔ)句,也就是我們所說(shuō)的SELECTS句,另外一種就是更新語(yǔ)句,也叫做數(shù)據(jù)操作語(yǔ)句。本文以MySQ師背景來(lái)討論如何使有SQL中的更新語(yǔ)句。一、INSERT和REPLACEINSERT和REPLAC暗句的功能都是向表中插入新的數(shù)據(jù)。這兩條語(yǔ)句的語(yǔ)法類(lèi)似。它們的主要區(qū)別是如何處理重復(fù)的數(shù)據(jù)。1.INSERT的一般用法MySQL中的INSERT語(yǔ)句和標(biāo)準(zhǔn)的INSERT不太一樣,在標(biāo)準(zhǔn)的SQL語(yǔ)句中,一次插入一條記錄的INSERT語(yǔ)句只有一種形式。INSERTINTOtablename(歹U名一)VALUES(歹
2、U值);而在MySQ中還有另外一種形式。r2INSERTINTOtablenameSETcolumn_name1=value1,column_name2=value2,;第一種方法將列名和列值分開(kāi)了,在使用時(shí),列名必須和列值的數(shù)一致。如下面的語(yǔ)句向users表中插入了一條記錄:INSERTINTOusers(id,name,age)VALUES(123,'姚明',25);第二種方法允許列名和列值成對(duì)出現(xiàn)和使用,如下面的語(yǔ)句將產(chǎn)生中樣的效果。INSERTINTOusersSETid=123,name='姚明',age=25;如果使用了SET方式,必須至少為一列賦值
3、。如果某一個(gè)字段使用了省缺值(如默認(rèn)或自增值),這兩種方法都可以省略這些字段。如id字段上使用了自增值,上面兩條語(yǔ)句可以寫(xiě)成如下形式:INSERTINTOusers(name,age)VALUES('姚明',25);INSERTINTOusesSETname='姚明',age=25;MySQLVALUES!也做了些變化。如果VALUE汕什么都不寫(xiě),那MySQLB使用表中每一列的默認(rèn)值來(lái)插入新記錄。INSERTINTOusers()VALUES();如果表名后什么都不寫(xiě),就表示向表中所有的字段賦值。使用這種方式,不僅在VALUE汕的值要和列數(shù)一致,而且順序不能顛倒
4、。INSERTINTOusersVALUES(123,'姚明',25);如果將INSERT語(yǔ)句寫(xiě)成如下形式MySQLB會(huì)報(bào)錯(cuò)。INSERTINTOusersVALUES('姚明',25);2 .使用INSERT插入多條記錄看到這個(gè)標(biāo)題也許大家會(huì)問(wèn),這有什么好說(shuō)的,調(diào)用多次INSERT語(yǔ)句不就可以插入多條記錄了嗎!但使用這種方法要增加服務(wù)器的負(fù)荷,因?yàn)?,?zhí)行每一次SQL服務(wù)器都要同樣對(duì)SQL進(jìn)行分析、優(yōu)化等操作。幸好MySQL供了另一種解決方案,就是使用一條INSERT語(yǔ)句來(lái)插入多條記錄。這并不是標(biāo)準(zhǔn)的SQL語(yǔ)法,因此只能在MySQL中使用。INSERTINTOu
5、sers(name,age)VALUES('姚明',25),('比爾.蓋茨',50),('火星人',600);上面的INSERT語(yǔ)句向users表中連續(xù)插入了3條記錄。值得注意的是,上面的INSERT語(yǔ)句中的VALUES后必須每一條記錄的值放到一對(duì)()中,中間使用","分割。假設(shè)有一個(gè)表tablelCREATETABLEtable1(nINT);如果要向table1中插入5條記錄,下面寫(xiě)法是錯(cuò)誤的:INSERTINTOtable1(i)VALUES(1,2,3,4,5);MySQLM會(huì)拋出下面的錯(cuò)誤IERROR1136:Col
6、umncountdoesn'tmatchvaluecountatrow1而正確的寫(xiě)法應(yīng)該是這樣:INSERTINTOtable1(i)VALUES(1),(2),(3),(4),(5);當(dāng)然,這種寫(xiě)法也可以省略列名,這樣每一對(duì)括號(hào)里的值的數(shù)目必須一致,而且這個(gè)數(shù)目必須和列數(shù)一致。如:INSERTINTOtable1VALUES(1),(2),(3),(4),(5);3 .REPLACE語(yǔ)句我們?cè)谑褂脭?shù)據(jù)庫(kù)時(shí)可能會(huì)經(jīng)常遇到這種情況。如果一個(gè)表在一個(gè)字段上建立了唯一索引,當(dāng)我們?cè)傧蜻@個(gè)表中使用已經(jīng)存在的鍵值插入一條記錄,那將會(huì)拋出一個(gè)主鍵沖突的錯(cuò)誤。當(dāng)然,我們可能想用新記錄的值來(lái)覆蓋原來(lái)的
7、記錄值。如果使用傳統(tǒng)的做法,必須先使用DELETE語(yǔ)句刪除原先的記錄,然后再使用INSERT插入新的記錄。而在MySQL中為我們提供了一種新的解決方案,這就是REPLAC斜句。使用REPLACE插入一條記錄時(shí),如果不重復(fù),REPLACEDINSERT的功能一樣,如果有重復(fù)記錄,REPLAC僦使用新記錄的值來(lái)替換原來(lái)的記錄值。使用REPLACE勺最大好處就是可以將DELETED口INSERT合二為一,形成一個(gè)原子操作。這樣就可以不必考慮在同時(shí)使用DELET臣口INSERT時(shí)添力事務(wù)等復(fù)雜操作了。在使用REPLACED表中必須有唯一索引,而且這個(gè)索引所在的字段不能允許空值,否則REPLACED和I
8、NSERT完全一樣的。在執(zhí)行REPLACED系統(tǒng)返回了所影響的行數(shù),如果返回1,說(shuō)明在表中并沒(méi)有重復(fù)的記錄,如果返回2,說(shuō)明有一條重復(fù)記錄,系統(tǒng)自動(dòng)先調(diào)用了DELETE刪除這條記錄,然后再記錄用INSERT來(lái)插入這條記錄。如果返回的值大于2,那說(shuō)明有多個(gè)唯一索引,有多條記錄被刪除和插入。REPLACE勺語(yǔ)法和INSERT非常的相似,如下面的REPLAC斜句是插入或更新一條記錄。REPLACEINTOusers(id,name,age)VALUES(123,趙本山',50);插入多條記錄:REPLACEINTOusers(id,name,age)VALUES(123,'趙本山
9、39;,50),(134,'Mary',15);REPLACE也可以使用SET語(yǔ)句REPLACEINTOusersSETid=123,name='趙本山',age=50;上面曾提到REPLAC圓能影響3條以上的記錄,這是因?yàn)樵诒碇杏谐^(guò)一個(gè)的唯一索引。在這種情況下,REPLAC酪考慮每一個(gè)唯一索引,并對(duì)每一個(gè)索引對(duì)應(yīng)的重復(fù)記錄都刪除,然后插入這條新記錄。假設(shè)有一個(gè)tablel表,有3個(gè)字段a,b,c。它們都有一個(gè)唯一索引。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ù)。這的語(yǔ)法和INSERT的第二種用法相似。必須提供表名以及SET表達(dá)式,在后面可以加WHEREZ限制更新的記錄范圍。FnUPDATEtable_anemSETc
11、olumn_name1=value1,column_name2=value2,WHERE;如下面的語(yǔ)句將users表中id等于123的記錄的age改為24UPDATEusersSETage=24WHEREid=123;同樣,可以使用UPDAT哽新多個(gè)字段的值UPDATEusersSETage=24,name='Mike'WHEREid=123;上面的UPDAT曲句通過(guò)WHERE1定一個(gè)條件,否則,UPDATE各更新表中的所有記錄的值。在使用UPDAT哽新記錄時(shí),如果被更新的字段的類(lèi)型和所賦的值不匹配時(shí),MySQLB這個(gè)值轉(zhuǎn)換為相應(yīng)類(lèi)型的值。如果這個(gè)字段是數(shù)值類(lèi)型,而且所賦值超過(guò)
12、了這個(gè)數(shù)據(jù)類(lèi)型的最大范圍,那么MySQ就將這個(gè)值轉(zhuǎn)換為這個(gè)范圍最大或最小值。如果字符串太長(zhǎng),MySQ就將多余的字符串截去。如果設(shè)置非空字段為空,那么將這個(gè)字段設(shè)置為它們的默認(rèn)值,數(shù)字的默認(rèn)值是0,字符串的默認(rèn)值是空串(不是null,是與o有兩種情況UPDAT環(huán)會(huì)對(duì)影響表中的數(shù)據(jù)。1 .當(dāng)WHER中的條件在表中沒(méi)有記錄和它匹配時(shí)。2 .當(dāng)我們將同樣的值賦給某個(gè)字段時(shí),如將字段abc賦為123',而abc的原值就是123'。和INSERTREPLAC1樣,UPDAT曲返回所更新的記錄數(shù)。但這些記錄數(shù)并不包括滿(mǎn)足WHER窿件的,但卻未被更新的記錄。如下同的UPDAT曲句就未更新任何記
13、錄。UPDATEusersSETage=30WHEREid=12;QueryOK,0rowsaffected(0.00sec)需要注意的時(shí),如果一個(gè)字段的類(lèi)型是TIMESTAMP那么這個(gè)字段在其它字段更新時(shí)自動(dòng)更新。在有些時(shí)候我彳門(mén)需要得到UPDAT所選擇的行數(shù),而不是被更新的行數(shù)。我們可以通過(guò)一些API來(lái)達(dá)到這個(gè)目的。如MySQ牌供的CAPI提供了一個(gè)選項(xiàng)可以得到你想要的記錄數(shù)。而MySQL勺JDBCW動(dòng)得到的默認(rèn)記錄數(shù)也是匹配的記錄數(shù)。UPDATE口REPLAC基本類(lèi)似,但是它們之間有兩點(diǎn)不同。1. UPDATE在沒(méi)有匹配記錄時(shí)彳f么都不做,而REPLAC在有重復(fù)記錄時(shí)更新,在沒(méi)有重復(fù)記錄
14、時(shí)插入。2. UPDAT時(shí)以選擇性地更新記錄的一部分字段。而REPLAC衽發(fā)現(xiàn)有重復(fù)記錄時(shí)就將這條記錄徹底刪除,再插入新的記錄。也就是說(shuō),將所有的字段都更新了。三、DELETEDTRUNCATETABLE在MySQL中有兩種方法可以刪除數(shù)據(jù),一種是DELETED句,另一種是TRUNCATETABLE句。DELETE句可以通過(guò)WHERE要?jiǎng)h除的記錄進(jìn)彳亍選擇。而使用TRUNCATEABLE將刪除表中的所有記錄。因此,DELETE語(yǔ)句更靈活。如果要清空表中的所有記錄,可以使用下面的兩種方法:DELETEFROMtable1TRUNCATETABLEtable1其中第二條記錄中的TABLE是可選的。
15、如果要?jiǎng)h除表中的部分記錄,只能使用DELETED句。DELETEFROMtable1WHERE;如果DELET環(huán)加WHER子句,那么它和TRUNCATEABLE是一樣的,但它們有一點(diǎn)不同,那就是DELETEW以返回被刪除的記錄數(shù),而TRUNCATETABLE回的是0。如果一個(gè)表中有自增字段,使用TRUNCATETABLE沒(méi)有WHERE句的DELETE!除所有記錄后,這個(gè)自增字段將起始值恢復(fù)成1.如果你不想這樣做的話,可以在DELETE語(yǔ)句中加上永真的WHERE如WHERE俅WHEREtrueDELETEFROMtable1WHERE1;上面的語(yǔ)句在執(zhí)行時(shí)將掃描每一條記錄。但它并不比較,因?yàn)檫@個(gè)WHER條件永遠(yuǎn)為true。這樣做雖然可以保持自增的最大值,但由于它是掃描了所有的記錄,因此,它的執(zhí)行成本要比沒(méi)有WHERE句的DELETE大得多。DELETEDHTRUNCATETABLE最大區(qū)別是DELET時(shí)以通過(guò)WHER踣句選擇要?jiǎng)h除的記錄。但執(zhí)行得速度不快。而且還可以返回被刪除的記錄數(shù)。而TRUNCATEABLE無(wú)法刪除指定的記錄,而且不能返回被刪除的記錄。但它執(zhí)行得非??臁Ec標(biāo)準(zhǔn)的SQL語(yǔ)句不同,DELETE持ORDERBY口LIMIT子句,通過(guò)這兩個(gè)子句,我們可以更好地控制要?jiǎng)h除的記錄。如當(dāng)我們只想刪除WHERE"句過(guò)濾出來(lái)的記錄的一部分,可以使用
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 古今異義詞的比較與應(yīng)用教學(xué)教案
- 語(yǔ)文基礎(chǔ)漢字識(shí)別:甲骨文字解讀教案
- 2025年新媒體運(yùn)營(yíng)與傳播考試題及答案
- 2025年信息技術(shù)應(yīng)用能力考試試卷及答案
- 2025年生命科學(xué)與醫(yī)學(xué)倫理考試試題及答案
- 2025年統(tǒng)計(jì)學(xué)及其應(yīng)用專(zhuān)業(yè)知識(shí)綜合考試卷及答案
- 2025年社會(huì)工作師職業(yè)考試試題及答案
- 2025年人力資源管理職稱(chēng)考試試題及答案
- 2025年公關(guān)與危機(jī)管理的理論與實(shí)踐能力考核考試卷及答案
- 2025年動(dòng)畫(huà)制作與創(chuàng)作技能考核試題及答案
- MOOC 光纖通信-南京郵電大學(xué) 中國(guó)大學(xué)慕課答案
- 律師事務(wù)所設(shè)立承諾書(shū)
- 2024陜西延長(zhǎng)石油氣田公司遴選選聘筆試參考題庫(kù)附帶答案詳解
- 安全與發(fā)展同步進(jìn)行
- 民盟入盟申請(qǐng)書(shū)(通用6篇)
- 調(diào)度自動(dòng)化系統(tǒng)主站信息自動(dòng)聯(lián)調(diào)技術(shù)規(guī)范
- 中藥材種植及深加工項(xiàng)目建議書(shū)
- 直腸惡性腫瘤的護(hù)理查房課件
- 稅收籌劃 第4版 課件全套 蔡昌 第1-12章 稅收籌劃的基礎(chǔ)理論-跨國(guó)經(jīng)營(yíng)的稅收籌劃
- 高等數(shù)學(xué)(南京理工大學(xué))智慧樹(shù)知到課后章節(jié)答案2023年下南京理工大學(xué)
- 光污染調(diào)查報(bào)告
評(píng)論
0/150
提交評(píng)論