全國計(jì)算機(jī)二級(jí)MySQL章節(jié)知識(shí)點(diǎn):Mysql數(shù)據(jù)庫語句的更新_第1頁
全國計(jì)算機(jī)二級(jí)MySQL章節(jié)知識(shí)點(diǎn):Mysql數(shù)據(jù)庫語句的更新_第2頁
全國計(jì)算機(jī)二級(jí)MySQL章節(jié)知識(shí)點(diǎn):Mysql數(shù)據(jù)庫語句的更新_第3頁
全國計(jì)算機(jī)二級(jí)MySQL章節(jié)知識(shí)點(diǎn):Mysql數(shù)據(jù)庫語句的更新_第4頁
全國計(jì)算機(jī)二級(jí)MySQL章節(jié)知識(shí)點(diǎn):Mysql數(shù)據(jù)庫語句的更新_第5頁
已閱讀5頁,還剩3頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、全國計(jì)算機(jī)二級(jí)MySQL章節(jié)知識(shí)點(diǎn):Mysql數(shù)據(jù)庫 語句的更新2018年全國計(jì)算機(jī)二級(jí) MySQL章節(jié)知識(shí)點(diǎn):Mysql數(shù)據(jù)庫語句的 更新用于操作數(shù)據(jù)庫的SQL一般分為兩種,一種是查詢語句,也就 是我們所說的SELECT語句,另外一種就是更新語句,也叫做數(shù)據(jù) 操作語句。言外之意,就是對(duì)數(shù)據(jù)進(jìn)行修改。在標(biāo)準(zhǔn)的 SQL中有3 個(gè)語句,它們是INSERT、UPDATE以及DELETE。在MySQL中又 多了一個(gè)REPLACE語句,因此,本文以MySQL為背景來討論如何 使有SQL中的更新語句。一、INSERT 和 REPLACEINSERT和REPLACE語句的功能都是向表中插入新的數(shù)據(jù)。這 兩條

2、語句的語法類似。它們的主要區(qū)別是如何處理重復(fù)的數(shù)據(jù)。1.INSERT的一般用法MySQL中的INSERT語句和標(biāo)準(zhǔn)的INSERT不太一樣,在標(biāo)準(zhǔn) 的SQL語句中,插入一條記錄的INSERT語句只有一種形式。INSERTINTOtablename名)VALUES(歹OS);而在MySQL中還有另外一種形式。INSERTINTOtablenameSETcolumn_name1=value1,column_name2=val ue2,;第一種方法將列名和列值分開了, 在使用時(shí),列名必須和列值的數(shù)一致。如下面的語句向users表中插入了一條記錄:INSERTINTOusers(id,name,age)

3、ALUES(123,姚明,25);第二種方法允許列名和列值成對(duì)出現(xiàn)和使用,如下面的語句將產(chǎn)生中樣的效果。INSERTINTOusersSETid=123,name= 明,age=25;如果使用了 SET方式,必須至少為一列賦值。如果某一個(gè)字段 使用了省缺值(如默認(rèn)或自增值),這兩種方法都可以省略這些字段。 如id字段上使用了自增值,上面兩條語句可以寫成如下形式:INSERTINTOusers(name,age)ALUES(姚明,25);INSERTINTOusesSETname=ft 明,age=25;MySQL在VALUES上也做了些變化。如果VALUES中什么都不 寫,那MySQL將使用表

4、中每一列的默認(rèn)值來插入新記錄。INSERTINTOusers()VALUES();如果表名后什么都不寫,就表示向表中所有的字段賦值。 使用這 種方式,不僅在VALUES中的值要和列數(shù)一致,而且順序不能顛倒。INSERTINTOusersVALUES(123,姚明,25);如果將INSERT語句寫成如下形式MySQL將會(huì)報(bào)錯(cuò)。INSERTINTOusersVALUES(姚明,25);.使用INSERT插入多條記錄看到這個(gè)標(biāo)題也許大家會(huì)問,這有什么好說的,調(diào)用多次INSERT語句不就可以插入多條記錄了嗎!但使用這種方法要增加服務(wù)器的負(fù) 荷,因?yàn)?,?zhí)行每SQL服務(wù)器都要同樣對(duì)SQL進(jìn)行分析、優(yōu)化等操

5、 作。幸好MySQL提供了另一種解決方案,就是使用一條INSERT語 句來插入多條記錄。這并不是標(biāo)準(zhǔn)的SQL語法,因此只能在MySQL 中使用。INSERTINTOusers(name,age)VALUES(姚明,25),(比爾.蓋茨,50),(火星人,600);上面的INSERT語句向users表中連續(xù)插入了 3條記錄。值得注 意的是,上面的INSERT語句中的VALUES后必須每一條記錄的值 放到一對(duì)()中,中間使用,分割。假設(shè)有一個(gè)表table1CREATETABLEtable1(nINT);如果要向table1中插入5條記錄,下面寫法是錯(cuò)誤的:INSERTINTOtable1(i)VA

6、LUES(1,2,3,4,5);MySQL將會(huì)拋出下面的錯(cuò)誤ERROR1136:Columncountdoesntmatchvaluecountatrow1而正確的寫法應(yīng)該是這樣:INSERTINTOtable1(i)VALUES(1),(2),(3),(4),(5);當(dāng)然,這種寫法也可以省略列名,這樣每一對(duì)括號(hào)里的值的數(shù)目 必須一致,而且這個(gè)數(shù)目必須和列數(shù)一致。如:INSERTINTOtable1VALUES(1),(2),(3),(4),(5);.REPLACE 語句我們?cè)谑褂脭?shù)據(jù)庫時(shí)可能會(huì)經(jīng)常遇到這種情況。如果一個(gè)表在一 個(gè)字段上建立了唯一索引,當(dāng)我們?cè)傧蜻@個(gè)表中使用已經(jīng)存在的鍵值 插入

7、一條記錄,那將會(huì)拋出一個(gè)主鍵沖突的錯(cuò)誤。當(dāng)然,我們可能想 用新記錄的值來覆蓋原來的記錄值。 如果使用傳統(tǒng)的做法,必須先使 用DELETE語句刪除原先的記錄,然后再使用INSERT插入新的記 錄。而在 MySQL中為我們提供了一種新的解決方案,這就是 REPLACE語句。使用 REPLACE插入一條記錄時(shí),如果不重復(fù), REPLACE就和INSERT的功能一樣,如果有重復(fù)記錄, REPLACE 就使用新記錄的值來替換原來的記錄值。使用REPLACE的最大好處就是可以將 DELETE和INSERT合二 為一,形成一個(gè)原子操作。這樣就可以不必考慮在同時(shí)使用 DELETE 和INSERT時(shí)添加事務(wù)等復(fù)

8、雜操作了。在使用REPLACE時(shí),表中必須有唯一索引,而且這個(gè)索引所在 的字段不能允許空值,否則 REPLACE就和INSERT完全一樣的。在執(zhí)行REPLACE后,系統(tǒng)返回了所影響的行數(shù),如果返回 1, 說明在表中并沒有重復(fù)的記錄,如果返回2,說明有一條重復(fù)記錄,系統(tǒng)自動(dòng)先調(diào)用了 DELETE刪除這條記錄,然后再記錄用INSERT 來插入這條記錄。如果返回的值大于 2,那說明有多個(gè)唯一索引,有 多條記錄被刪除和插入。REPLACE的語法和INSERT非常的相似,如下面的 REPLACE 語句是插入或更新一條記錄。REPLACEINTOusers(id,name,age)ALUES(123,趙本

9、山,50);插入多條記錄:REPLACEINTOusers(id,name,age)VALUES(123,趙本山,50),(134,Mary,15);REPLACE也可以使用SET語句REPLACEINTOusersSETid=123,name忐本山,age=50;上面曾提到REPLACE可能影響3條以上的記錄,這是因?yàn)樵诒?中有超過一個(gè)的唯一索引。在這種情況下,REPLACE將考慮每一個(gè) 唯一索引,并對(duì)每一個(gè)索引對(duì)應(yīng)的重復(fù)記錄都刪除, 然后插入這條新 記錄。假設(shè)有一個(gè)tablel表,有3個(gè)字段a,b,c。它們都有一個(gè)唯一索 引。CREATETABLEtable1(aINTNOTNULLUNI

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

11、面可以加 WHERE 以限制更新的記錄范圍。UPDATEtable_anemSETcolumn_name1=value1,column_name2=value2, .WHERE.;如下面的語句將users表中id等于123的記錄的age改為24UPDATEusersSETage=24WHEREid=123;同樣,可以使用 UPDATE 更新多個(gè)字段的值UPDATEusersSETage=24,name=MikeWHEREid=123;上面的UPDATE語句通過 WHERE指定一個(gè)條件,否則, UPDATE將更新表中的所有記錄的值。在使用UPDATE更新記錄時(shí),如果被更新的字段的類型和所賦的值不

12、匹配時(shí),MySQL將這個(gè)值轉(zhuǎn)換為相應(yīng)類型的值。如果這個(gè)字 段是數(shù)值類型,而且所賦值超過了這個(gè)數(shù)據(jù)類型的最大范圍,那么 MySQL就將這個(gè)值轉(zhuǎn)換為這個(gè)范圍最大或最小值。 如果字符串太長,MySQL就將多余的字符串截去。如果設(shè)置非空字段為空,那么將這個(gè)字段設(shè)置為它們的默認(rèn)值,數(shù)字的默認(rèn)值是 0,字符串的默認(rèn)值是空串(不是null,是)。有兩種情況UPDATE不會(huì)對(duì)影響表中的數(shù)據(jù)。.當(dāng)WHERE中的條件在表中沒有記錄和它匹配時(shí)。.當(dāng)我們將同樣的值賦給某個(gè)字段時(shí),如將字段abc賦為123,而abc的原值就是123。和INSERT、REPLACE一樣,UPDATE也返回所更新的t己錄數(shù)。 但這些記錄數(shù)并

13、不包括滿足WHERE條件的,但卻未被更新的記錄。 如下同的UPDATE語句就未更新任何記錄。UPDATEusersSETage=30WHEREid=12;QueryOK,0rowsaffected(0.00sec)需要注意的時(shí),如果一個(gè)字段的類型是 TIMESTAMP ,那么這個(gè) 字段在其它字段更新時(shí)自動(dòng)更新。在有些時(shí)候我們需要得到 UPDATE所選擇的行數(shù),而不是被更 新的行數(shù)。我們可以通過一些 API來達(dá)到這個(gè)目的。如MySQL提供 的CAPI提供了一個(gè)選項(xiàng)可以得到你想要的記錄數(shù)。而 MySQL的 JDBC驅(qū)動(dòng)得到的默認(rèn)記錄數(shù)也是匹配的記錄數(shù)。UPDATE和REPLACE基本類似,但是它們之間有兩點(diǎn)不同。.UPDATE在沒有匹配記錄時(shí)什么都不做,而 REPLACE在有重 復(fù)記錄時(shí)更新,在沒有重復(fù)記錄時(shí)插入。.UPDATE可以選擇性地更新記錄的一部

溫馨提示

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

最新文檔

評(píng)論

0/150

提交評(píng)論