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