sql查詢語句教程之插入、更新和刪除數(shù)據(jù)實(shí)例
前言
數(shù)據(jù)庫通過插入、更新和刪除等方式來改變表中的記錄。插入數(shù)據(jù)是向表中插入新的記錄,通過 INSERT 語句來實(shí)現(xiàn)。更新數(shù)據(jù)是改變表中已經(jīng)存在的數(shù)據(jù),使用UPDATE 語句來實(shí)現(xiàn)。刪除數(shù)據(jù)是刪除表中不再使用的數(shù)據(jù),通過DELETE 語句來實(shí)現(xiàn)。
1、插入數(shù)據(jù)
插入數(shù)據(jù)是向表中插入新的記錄。通過這種方式可以為表中增加新的數(shù)據(jù)。在 MySQL中,通過INSERT語句來插入新的數(shù)據(jù)。使用INSERT 語句可以同時(shí)為表的所有字段插入數(shù)據(jù),也可以為表的指定字段插入數(shù)據(jù)。INSERT語句可以同時(shí)插入多條記錄,還可以將一個(gè)表中查詢出來的數(shù)據(jù)插入到另一個(gè)表中。
1.1 為表的所有字段插入數(shù)據(jù)
通常情況下,插入的新記錄要包含表的所有字段。INSERT 語句有兩種方式可以同時(shí)為表的所有字段插入數(shù)據(jù)。第一種方式是不指定具體的字段名;第二種方式是列出表的所有字段。
1、insert語句中不指定具體的字段名
在 MySQL中,可以通過不指定字段名的方式為表插入記錄。其基本語句形式如下:
insert into 表名 values(值1,值2,...,值n);
其中,“表名”參數(shù)指定記錄插入到哪個(gè)表中;“值n”參數(shù)表示要插入的數(shù)據(jù)。“值1”到“值n”分別對應(yīng)著表中的每個(gè)字段。表中定義了幾個(gè)字段,INSERT語句中就應(yīng)該對應(yīng)有幾個(gè)值。插入的順序與表中字段的順序相同。而且,取值的數(shù)據(jù)類型要與表中對應(yīng)字段的數(shù)據(jù)類型一致。
下面向S表中插入記錄。插入記錄之前,可以通過DESC語句來查看S表的基本結(jié)構(gòu)。查詢結(jié)果如下:
從查詢結(jié)果可以看出,S表包含4個(gè)字段。那么INSERT 語句中的值也應(yīng)該是4個(gè)。INSERT語句的代碼如下:
!??!字符串類型的數(shù)據(jù),取值必須加上引號(hào)。
2、insert語句中列出所有字段
INSERT語句中可以列出表的所有字段,為這些字段來插入數(shù)據(jù)。其基本語句形式如下:
insert into 表名(屬性1,屬性2,...,屬性n) values (值1,值2,...,值n);
其中,“屬性n”參數(shù)表示表中的字段名稱,此處必須列出表的所有字段的名稱;“值n”參數(shù)表示每個(gè)字段的值,每個(gè)值與相應(yīng)的字段對應(yīng)。
下面向S表中插入一條新記錄。INSERT 語句的代碼如下:
查詢結(jié)果顯示,記錄已經(jīng)插入成功。如果表的字段比較多,用第二種方法就比較麻煩。但是,第二種方法比較靈活??梢噪S意的設(shè)置字段的順序,而不需要按照表定義時(shí)的順序。值的順序也必須跟著字段順序的改變而改變。
下面向S表中插入一條新記錄。INSERT語句中字段的順序與表定義時(shí)的順序不同。INSERT語句的代碼如下:
1.2 為表的指定字段插入數(shù)據(jù)
其基本語句形式如下:
insert into 表名(屬性1,屬性2,…,屬性m) values(值1,值2,.…,值m);
其中,“屬性m”參數(shù)表示表中的字段名稱,此處指定表的部分字段的名稱;“值m”參數(shù)表示指定字段的值,每個(gè)值與相應(yīng)的字段對應(yīng)。
下面向S表的sno和sname這2個(gè)字段插入數(shù)據(jù)。INSERT語句的代碼如下:
這種方式也可以隨意的設(shè)置字段的順序,而不需要按照表定義時(shí)的順序。
?。?!沒有賦值的字段,數(shù)據(jù)庫系統(tǒng)會(huì)為其插入默認(rèn)值。這個(gè)默認(rèn)值是在創(chuàng)建表的時(shí)候定義的。如上面function字段和address字段的默認(rèn)值為NULL。如果某個(gè)字段沒有設(shè)置默認(rèn)值,而且是非空,這就必須為其賦值。不然數(shù)據(jù)庫系統(tǒng)會(huì)提示“Field'name' doesn't have a default value”這樣的錯(cuò)誤。
1.3 同時(shí)插入多條記錄
同時(shí)插入多條記錄,是指一個(gè) INSERT語句插入多條記錄。當(dāng)用戶需要插入好幾條記錄,用戶可以使用上面兩個(gè)小節(jié)中的方法逐條插入記錄。但是,每次都要寫一個(gè)新的INSERT 語句。這樣比較麻煩。MySQL 中,一個(gè) INSERT語句可以同時(shí)插入多條記錄。其基本語法形式如下:
insert into 表名[(屬性列表)】 values (取值列表1),(取值列表2), ..., (取值列表n);
其中,“表名”參數(shù)指明向哪個(gè)表中插入數(shù)據(jù);“屬性列表”參數(shù)是可選參數(shù),指定哪些字段插入數(shù)據(jù),沒有指定字段時(shí)向所有字段插入數(shù)據(jù);“取值列表n”參數(shù)表示要插入的記錄,每條記錄之間用逗號(hào)隔開。
向MySQL的某個(gè)表中插入多條記錄時(shí),可以使用多個(gè)INSERT語句逐條插入記錄,也可以使用一個(gè) INSERT語句插入多條記錄。選擇哪種方式通常根據(jù)個(gè)人喜好來決定。如果插入的記錄很多時(shí),一個(gè)INSERT 語句插入多條記錄的方式的速度會(huì)比較快。
下面向S表中插入3條新記錄。INSERT 語句的代碼如下:
不指定字段時(shí),必須為每個(gè)字段都插入數(shù)據(jù)。如果指定字段,就只需要為指定的字段插入數(shù)據(jù)。
1.4 將查詢結(jié)果插入到表中
INSERT語句可以將一個(gè)表中查詢出來的數(shù)據(jù)插入到另一表中。這樣,可以方便不同表之間進(jìn)行數(shù)據(jù)交換。其基本語法形式如下:
insert into 表名1(屬性列表1) select 屬性列表2 from 表名2 where 條件表達(dá)式;
其中,“表名1”參數(shù)說明記錄插入到哪個(gè)表中;“表名2”參數(shù)表示記錄是從哪個(gè)表中查詢出來的;“屬性列表1”參數(shù)表示為哪些字段賦值;“屬性列表2”表示從表中查詢出哪些字段的數(shù)據(jù);“條件表達(dá)式”參數(shù)設(shè)置了SELECT 語句的查詢條件。
使用這種方法時(shí),必須保證“字段列表1”和“字段列表2”中的字段個(gè)數(shù)是一樣的。而且,每個(gè)對應(yīng)的字段的數(shù)據(jù)類型是一樣的。如果數(shù)據(jù)類型不一樣,數(shù)據(jù)庫系統(tǒng)會(huì)報(bào)錯(cuò)。然后,阻止INSERT語句向下執(zhí)行。
下面將s_temp表中所有數(shù)據(jù)查詢出來,然后插入到S表中。插入之前,先執(zhí)行SELECT語句來查看s_temp表中的記錄。SELECT語句執(zhí)行結(jié)果如下:
2、更新數(shù)據(jù)
更新數(shù)據(jù)是更新表中已經(jīng)存在的記錄。通過這種方式可以改變表中已經(jīng)存在的數(shù)據(jù)。例如,學(xué)生表中某個(gè)學(xué)生的家庭住址改變了,這就需要在學(xué)生表中修改該同學(xué)的家庭地址。在MySQL中,通過UPDATE語句來更新數(shù)據(jù)。
在 MySQL中,UPDATE語句的基本語法形式如下:
update 表名 set 屬性名1=取值1,屬性名2=取值2, ..., 屬性名n=取值n where 條件表達(dá)式;
其中,“屬性名n”參數(shù)表示需要更新的字段的名稱;“取值 n”參數(shù)表示為字段更新的新數(shù)據(jù);“條件表達(dá)式”參數(shù)指定更新滿足條件的記錄。
下面更新s表中sno值為s1的記錄。將sname字段的值變?yōu)?lsquo;精益求精‘,city的值變?yōu)?rsquo;北京‘。
表中滿足條件表達(dá)式的記錄可能不止一條。使用UPDATE語句會(huì)更新所有滿足條件的記錄。
下面更新S表中 sno值為s100-s102的記錄。將status字段的值變?yōu)?0。將city字段的值變?yōu)?ldquo;天津”。
?。?!使用UPDATE語句更新數(shù)據(jù)時(shí),可能會(huì)有多條記錄滿足WHERE條件。這個(gè)時(shí)候一定要特別小心,最好先執(zhí)行SELECT語句判斷滿足WHERE條件的記錄是否確實(shí)是需要更新的。如果其中有些記錄不需要更新,應(yīng)該重新設(shè)置WHERE條件.
3、刪除數(shù)據(jù)
刪除數(shù)據(jù)是刪除表中已經(jīng)存在的記錄。通過這種方式可以刪除表中不再使用的記錄。例如,學(xué)生表中某個(gè)學(xué)生退學(xué)了,這就需要從學(xué)生表中刪除該同學(xué)的信息。MySQL中,通過DELETE 語句來刪除數(shù)據(jù)。
MySQL中,DELETE語句的基本語法形式如下:
delete from 表名[where條件表達(dá)式】;
其中,“表名”參數(shù)指明從哪個(gè)表中刪除數(shù)據(jù);“WHERE條件表達(dá)式”指定刪除表中的哪些數(shù)據(jù)。如果沒有該條件表達(dá)式,數(shù)據(jù)庫系統(tǒng)就會(huì)刪除表中的所有數(shù)據(jù)。
下面刪除s表中sno值為s1的記錄。
DELETE語句可以同時(shí)刪除多條記錄。
下面刪除s表中 city值為‘北京’的記錄。
DELETE語句中如果不加上“WHERE條件表達(dá)式”,數(shù)據(jù)庫系統(tǒng)會(huì)刪除指定表中的所有數(shù)據(jù)。
下面刪除s表中的所有記錄。
因?yàn)閳?zhí)行DELETE語句后,會(huì)將記錄從表中刪除。刪除過程中不會(huì)有任何提示,因此必須要特別小心。在條件允許的情況下,最好先用SELECT語句查詢準(zhǔn)備刪除的記錄。這樣可以確認(rèn)這些記錄確實(shí)是需要?jiǎng)h除的。
總結(jié)
到此這篇關(guān)于sql查詢語句教程之插入、更新和刪除數(shù)據(jù)的文章就介紹到這了,更多相關(guān)sql插入更新和刪除數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
php中如何將圖片儲(chǔ)存在數(shù)據(jù)庫里
php中如何將圖片儲(chǔ)存在數(shù)據(jù)庫里...2007-03-03MYSQL 隨機(jī) 抽取實(shí)現(xiàn)方法及效率分析
MYSQL的隨機(jī)抽取實(shí)現(xiàn)方法。舉個(gè)例子,要從tablename表中隨機(jī)提取一條記錄,大家一般的寫法就是:SELECT * FROM tablename ORDER BY RAND() LIMIT 1。2009-05-05Mysql 導(dǎo)入導(dǎo)出csv 中文亂碼問題的解決方法
這篇文章介紹了Mysql 導(dǎo)入導(dǎo)出csv 中文亂碼問題的解決方法,有需要的朋友可以參考一下2013-09-09