




版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、全國(guó)計(jì)算機(jī)二級(jí)MySQL章節(jié)知識(shí)點(diǎn):Mysql數(shù)據(jù)庫(kù) 語(yǔ)句的更新2018年全國(guó)計(jì)算機(jī)二級(jí) MySQL章節(jié)知識(shí)點(diǎn):Mysql數(shù)據(jù)庫(kù)語(yǔ)句的 更新用于操作數(shù)據(jù)庫(kù)的SQL一般分為兩種,一種是查詢(xún)語(yǔ)句,也就 是我們所說(shuō)的SELECT語(yǔ)句,另外一種就是更新語(yǔ)句,也叫做數(shù)據(jù) 操作語(yǔ)句。言外之意,就是對(duì)數(shù)據(jù)進(jìn)行修改。在標(biāo)準(zhǔn)的 SQL中有3 個(gè)語(yǔ)句,它們是INSERT、UPDATE以及DELETE。在MySQL中又 多了一個(gè)REPLACE語(yǔ)句,因此,本文以MySQL為背景來(lái)討論如何 使有SQL中的更新語(yǔ)句。一、INSERT 和 REPLACEINSERT和REPLACE語(yǔ)句的功能都是向表中插入新的數(shù)據(jù)。這 兩條
2、語(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名)VALUES(歹OS);而在MySQL中還有另外一種形式。INSERTINTOtablenameSETcolumn_name1=value1,column_name2=val ue2,;第一種方法將列名和列值分開(kāi)了, 在使用時(shí),列名必須和列值的數(shù)一致。如下面的語(yǔ)句向users表中插入了一條記錄:INSERTINTOusers(id,name,age)
3、ALUES(123,姚明,25);第二種方法允許列名和列值成對(duì)出現(xiàn)和使用,如下面的語(yǔ)句將產(chǎn)生中樣的效果。INSERTINTOusersSETid=123,name= 明,age=25;如果使用了 SET方式,必須至少為一列賦值。如果某一個(gè)字段 使用了省缺值(如默認(rèn)或自增值),這兩種方法都可以省略這些字段。 如id字段上使用了自增值,上面兩條語(yǔ)句可以寫(xiě)成如下形式:INSERTINTOusers(name,age)ALUES(姚明,25);INSERTINTOusesSETname=ft 明,age=25;MySQL在VALUES上也做了些變化。如果VALUES中什么都不 寫(xiě),那MySQL將使用表
4、中每一列的默認(rèn)值來(lái)插入新記錄。INSERTINTOusers()VALUES();如果表名后什么都不寫(xiě),就表示向表中所有的字段賦值。 使用這 種方式,不僅在VALUES中的值要和列數(shù)一致,而且順序不能顛倒。INSERTINTOusersVALUES(123,姚明,25);如果將INSERT語(yǔ)句寫(xiě)成如下形式MySQL將會(huì)報(bào)錯(cuò)。INSERTINTOusersVALUES(姚明,25);.使用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)化等操
5、 作。幸好MySQL提供了另一種解決方案,就是使用一條INSERT語(yǔ) 句來(lái)插入多條記錄。這并不是標(biāo)準(zhǔn)的SQL語(yǔ)法,因此只能在MySQL 中使用。INSERTINTOusers(name,age)VALUES(姚明,25),(比爾.蓋茨,50),(火星人,600);上面的INSERT語(yǔ)句向users表中連續(xù)插入了 3條記錄。值得注 意的是,上面的INSERT語(yǔ)句中的VALUES后必須每一條記錄的值 放到一對(duì)()中,中間使用,分割。假設(shè)有一個(gè)表table1CREATETABLEtable1(nINT);如果要向table1中插入5條記錄,下面寫(xiě)法是錯(cuò)誤的:INSERTINTOtable1(i)VA
6、LUES(1,2,3,4,5);MySQL將會(huì)拋出下面的錯(cuò)誤ERROR1136:Columncountdoesntmatchvaluecountatrow1而正確的寫(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);.REPLACE 語(yǔ)句我們?cè)谑褂脭?shù)據(jù)庫(kù)時(shí)可能會(huì)經(jīng)常遇到這種情況。如果一個(gè)表在一 個(gè)字段上建立了唯一索引,當(dāng)我們?cè)傧蜻@個(gè)表中使用已經(jīng)存在的鍵值 插入
7、一條記錄,那將會(huì)拋出一個(gè)主鍵沖突的錯(cuò)誤。當(dāng)然,我們可能想 用新記錄的值來(lái)覆蓋原來(lái)的記錄值。 如果使用傳統(tǒng)的做法,必須先使 用DELETE語(yǔ)句刪除原先的記錄,然后再使用INSERT插入新的記 錄。而在 MySQL中為我們提供了一種新的解決方案,這就是 REPLACE語(yǔ)句。使用 REPLACE插入一條記錄時(shí),如果不重復(fù), REPLACE就和INSERT的功能一樣,如果有重復(fù)記錄, REPLACE 就使用新記錄的值來(lái)替換原來(lái)的記錄值。使用REPLACE的最大好處就是可以將 DELETE和INSERT合二 為一,形成一個(gè)原子操作。這樣就可以不必考慮在同時(shí)使用 DELETE 和INSERT時(shí)添加事務(wù)等復(fù)
8、雜操作了。在使用REPLACE時(shí),表中必須有唯一索引,而且這個(gè)索引所在 的字段不能允許空值,否則 REPLACE就和INSERT完全一樣的。在執(zhí)行REPLACE后,系統(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非常的相似,如下面的 REPLACE 語(yǔ)句是插入或更新一條記錄。REPLACEINTOusers(id,name,age)ALUES(123,趙本
9、山,50);插入多條記錄:REPLACEINTOusers(id,name,age)VALUES(123,趙本山,50),(134,Mary,15);REPLACE也可以使用SET語(yǔ)句REPLACEINTOusersSETid=123,name忐本山,age=50;上面曾提到REPLACE可能影響3條以上的記錄,這是因?yàn)樵诒?中有超過(guò)一個(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語(yǔ)句向table1中插入一條記錄。REPLACEINTOtable1(a,b,c)VALUES(1,2,3);返回的結(jié)果如下QueryOK,4rowsaffected(0.00sec)在table1中的記錄如下abc123我們可以看到,REPLACE將原先的3條記錄都刪除了,然后將(1,2,3)插入。二、UPDATEUPDATE的功能是更新表中的數(shù)據(jù)。這的語(yǔ)法和INSERT的第二 種用法相似。必須提供表名以及SET表達(dá)式,在后
11、面可以加 WHERE 以限制更新的記錄范圍。UPDATEtable_anemSETcolumn_name1=value1,column_name2=value2, .WHERE.;如下面的語(yǔ)句將users表中id等于123的記錄的age改為24UPDATEusersSETage=24WHEREid=123;同樣,可以使用 UPDATE 更新多個(gè)字段的值UPDATEusersSETage=24,name=MikeWHEREid=123;上面的UPDATE語(yǔ)句通過(guò) WHERE指定一個(gè)條件,否則, UPDATE將更新表中的所有記錄的值。在使用UPDATE更新記錄時(shí),如果被更新的字段的類(lèi)型和所賦的值不
12、匹配時(shí),MySQL將這個(gè)值轉(zhuǎn)換為相應(yīng)類(lèi)型的值。如果這個(gè)字 段是數(shù)值類(lèi)型,而且所賦值超過(guò)了這個(gè)數(shù)據(jù)類(lèi)型的最大范圍,那么 MySQL就將這個(gè)值轉(zhuǎn)換為這個(gè)范圍最大或最小值。 如果字符串太長(zhǎng),MySQL就將多余的字符串截去。如果設(shè)置非空字段為空,那么將這個(gè)字段設(shè)置為它們的默認(rèn)值,數(shù)字的默認(rèn)值是 0,字符串的默認(rèn)值是空串(不是null,是)。有兩種情況UPDATE不會(huì)對(duì)影響表中的數(shù)據(jù)。.當(dāng)WHERE中的條件在表中沒(méi)有記錄和它匹配時(shí)。.當(dāng)我們將同樣的值賦給某個(gè)字段時(shí),如將字段abc賦為123,而abc的原值就是123。和INSERT、REPLACE一樣,UPDATE也返回所更新的t己錄數(shù)。 但這些記錄數(shù)并
13、不包括滿(mǎn)足WHERE條件的,但卻未被更新的記錄。 如下同的UPDATE語(yǔ)句就未更新任何記錄。UPDATEusersSETage=30WHEREid=12;QueryOK,0rowsaffected(0.00sec)需要注意的時(shí),如果一個(gè)字段的類(lèi)型是 TIMESTAMP ,那么這個(gè) 字段在其它字段更新時(shí)自動(dòng)更新。在有些時(shí)候我們需要得到 UPDATE所選擇的行數(shù),而不是被更 新的行數(shù)。我們可以通過(guò)一些 API來(lái)達(dá)到這個(gè)目的。如MySQL提供 的CAPI提供了一個(gè)選項(xiàng)可以得到你想要的記錄數(shù)。而 MySQL的 JDBC驅(qū)動(dòng)得到的默認(rèn)記錄數(shù)也是匹配的記錄數(shù)。UPDATE和REPLACE基本類(lèi)似,但是它們之間有兩點(diǎn)不同。.UPDATE在沒(méi)有匹配記錄時(shí)什么都不做,而 REPLACE在有重 復(fù)記錄時(shí)更新,在沒(méi)有重復(fù)記錄時(shí)插入。.UPDATE可以選擇性地更新記錄的一部
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 社會(huì)支持網(wǎng)絡(luò)構(gòu)建-第1篇-全面剖析
- 智能家居系統(tǒng)安全性研究-全面剖析
- 游樂(lè)園餐飲創(chuàng)新趨勢(shì)-全面剖析
- 火星生態(tài)循環(huán)技術(shù)-全面剖析
- 知識(shí)產(chǎn)權(quán)保護(hù)趨勢(shì)-全面剖析
- 油氣資源環(huán)境友好處理-全面剖析
- 污水處理大數(shù)據(jù)分析-全面剖析
- 2025-2030藤制家具產(chǎn)業(yè)政府戰(zhàn)略管理與區(qū)域發(fā)展戰(zhàn)略研究報(bào)告
- 2025-2030網(wǎng)絡(luò)檢測(cè)設(shè)備行業(yè)市場(chǎng)發(fā)展分析及發(fā)展趨勢(shì)前景預(yù)測(cè)報(bào)告
- 2025-2030糖尿病食品行業(yè)市場(chǎng)深度分析及前景趨勢(shì)與投資研究報(bào)告
- 2025年新高考?xì)v史預(yù)測(cè)模擬試卷浙江卷(含答案解析)
- 義烏市事業(yè)單位招聘考試真題2024
- 企業(yè)廉潔風(fēng)險(xiǎn)防控課件教學(xué)
- T-SDFA 047-2024 混合型飼料添加劑中卡那霉素的測(cè)定 液相色譜-串聯(lián)質(zhì)譜法
- 2025年管道工(高級(jí))職業(yè)技能鑒定參考試題(附答案)
- 成品油柴油汽油運(yùn)輸合同5篇
- 大數(shù)據(jù)與會(huì)計(jì)專(zhuān)業(yè)專(zhuān)業(yè)的實(shí)習(xí)報(bào)告
- JT-T-4-2019公路橋梁板式橡膠支座
- 火龍罐綜合灸療法
- 倉(cāng)庫(kù)管理員崗位職責(zé)說(shuō)明書(shū)
- H型鋼截面尺寸、理論重量和表面積計(jì)算表
評(píng)論
0/150
提交評(píng)論