sql查詢語句教程之插入、更新和刪除數據實例

前言

數據庫通過插入、更新和刪除等方式來改變表中的記錄。插入數據是向表中插入新的記錄,通過 INSERT 語句來實現。更新數據是改變表中已經存在的數據,使用UPDATE 語句來實現。刪除數據是刪除表中不再使用的數據,通過DELETE 語句來實現。

1、插入數據

插入數據是向表中插入新的記錄。通過這種方式可以為表中增加新的數據。在 MySQL中,通過INSERT語句來插入新的數據。使用INSERT 語句可以同時為表的所有字段插入數據,也可以為表的指定字段插入數據。INSERT語句可以同時插入多條記錄,還可以將一個表中查詢出來的數據插入到另一個表中。

1.1 為表的所有字段插入數據

通常情況下,插入的新記錄要包含表的所有字段。INSERT 語句有兩種方式可以同時為表的所有字段插入數據。第一種方式是不指定具體的字段名;第二種方式是列出表的所有字段。

1、insert語句中不指定具體的字段名

在 MySQL中,可以通過不指定字段名的方式為表插入記錄。其基本語句形式如下:

insert into 表名 values(值1,值2,...,值n);

其中,“表名”參數指定記錄插入到哪個表中;“值n”參數表示要插入的數據。“值1”到“值n”分別對應著表中的每個字段。表中定義瞭幾個字段,INSERT語句中就應該對應有幾個值。插入的順序與表中字段的順序相同。而且,取值的數據類型要與表中對應字段的數據類型一致。

下面向S表中插入記錄。插入記錄之前,可以通過DESC語句來查看S表的基本結構。查詢結果如下:

從查詢結果可以看出,S表包含4個字段。那麼INSERT 語句中的值也應該是4個。INSERT語句的代碼如下:

 !!!字符串類型的數據,取值必須加上引號。

2、insert語句中列出所有字段

INSERT語句中可以列出表的所有字段,為這些字段來插入數據。其基本語句形式如下:

insert into 表名(屬性1,屬性2,...,屬性n)
values (值1,值2,...,值n);

其中,“屬性n”參數表示表中的字段名稱,此處必須列出表的所有字段的名稱;“值n”參數表示每個字段的值,每個值與相應的字段對應。

下面向S表中插入一條新記錄。INSERT 語句的代碼如下:

查詢結果顯示,記錄已經插入成功。如果表的字段比較多,用第二種方法就比較麻煩。但是,第二種方法比較靈活。可以隨意的設置字段的順序,而不需要按照表定義時的順序。值的順序也必須跟著字段順序的改變而改變。

下面向S表中插入一條新記錄。INSERT語句中字段的順序與表定義時的順序不同。INSERT語句的代碼如下:

1.2 為表的指定字段插入數據

其基本語句形式如下:

insert into 表名(屬性1,屬性2,…,屬性m)
values(值1,值2,.…,值m);

其中,“屬性m”參數表示表中的字段名稱,此處指定表的部分字段的名稱;“值m”參數表示指定字段的值,每個值與相應的字段對應。

下面向S表的sno和sname這2個字段插入數據。INSERT語句的代碼如下:

這種方式也可以隨意的設置字段的順序,而不需要按照表定義時的順序。

!!!沒有賦值的字段,數據庫系統會為其插入默認值。這個默認值是在創建表的時候定義的。如上面function字段和address字段的默認值為NULL。如果某個字段沒有設置默認值,而且是非空,這就必須為其賦值。不然數據庫系統會提示“Field'name' doesn't have a default value”這樣的錯誤。

1.3 同時插入多條記錄

同時插入多條記錄,是指一個 INSERT語句插入多條記錄。當用戶需要插入好幾條記錄,用戶可以使用上面兩個小節中的方法逐條插入記錄。但是,每次都要寫一個新的INSERT 語句。這樣比較麻煩。MySQL 中,一個 INSERT語句可以同時插入多條記錄。其基本語法形式如下:

insert into 表名[(屬性列表)】
values (取值列表1),(取值列表2),
...,
(取值列表n);

其中,“表名”參數指明向哪個表中插入數據;“屬性列表”參數是可選參數,指定哪些字段插入數據,沒有指定字段時向所有字段插入數據;“取值列表n”參數表示要插入的記錄,每條記錄之間用逗號隔開。

向MySQL的某個表中插入多條記錄時,可以使用多個INSERT語句逐條插入記錄,也可以使用一個 INSERT語句插入多條記錄。選擇哪種方式通常根據個人喜好來決定。如果插入的記錄很多時,一個INSERT 語句插入多條記錄的方式的速度會比較快。

下面向S表中插入3條新記錄。INSERT 語句的代碼如下:

不指定字段時,必須為每個字段都插入數據。如果指定字段,就隻需要為指定的字段插入數據。

1.4 將查詢結果插入到表中

INSERT語句可以將一個表中查詢出來的數據插入到另一表中。這樣,可以方便不同表之間進行數據交換。其基本語法形式如下:

insert into 表名1(屬性列表1)
select 屬性列表2 from 表名2 where 條件表達式;

其中,“表名1”參數說明記錄插入到哪個表中;“表名2”參數表示記錄是從哪個表中查詢出來的;“屬性列表1”參數表示為哪些字段賦值;“屬性列表2”表示從表中查詢出哪些字段的數據;“條件表達式”參數設置瞭SELECT 語句的查詢條件。

使用這種方法時,必須保證“字段列表1”和“字段列表2”中的字段個數是一樣的。而且,每個對應的字段的數據類型是一樣的。如果數據類型不一樣,數據庫系統會報錯。然後,阻止INSERT語句向下執行。

下面將s_temp表中所有數據查詢出來,然後插入到S表中。插入之前,先執行SELECT語句來查看s_temp表中的記錄。SELECT語句執行結果如下:

2、更新數據

更新數據是更新表中已經存在的記錄。通過這種方式可以改變表中已經存在的數據。例如,學生表中某個學生的傢庭住址改變瞭,這就需要在學生表中修改該同學的傢庭地址。在MySQL中,通過UPDATE語句來更新數據。

在 MySQL中,UPDATE語句的基本語法形式如下:

update 表名
set 屬性名1=取值1,屬性名2=取值2,
...,
屬性名n=取值n
where 條件表達式;

其中,“屬性名n”參數表示需要更新的字段的名稱;“取值 n”參數表示為字段更新的新數據;“條件表達式”參數指定更新滿足條件的記錄。

下面更新s表中sno值為s1的記錄。將sname字段的值變為‘精益求精‘,city的值變為’北京‘。

表中滿足條件表達式的記錄可能不止一條。使用UPDATE語句會更新所有滿足條件的記錄。

下面更新S表中 sno值為s100-s102的記錄。將status字段的值變為30。將city字段的值變為“天津”。

!!!使用UPDATE語句更新數據時,可能會有多條記錄滿足WHERE條件。這個時候一定要特別小心,最好先執行SELECT語句判斷滿足WHERE條件的記錄是否確實是需要更新的。如果其中有些記錄不需要更新,應該重新設置WHERE條件.

3、刪除數據

刪除數據是刪除表中已經存在的記錄。通過這種方式可以刪除表中不再使用的記錄。例如,學生表中某個學生退學瞭,這就需要從學生表中刪除該同學的信息。MySQL中,通過DELETE 語句來刪除數據。

MySQL中,DELETE語句的基本語法形式如下:

delete from 表名[where條件表達式】;

其中,“表名”參數指明從哪個表中刪除數據;“WHERE條件表達式”指定刪除表中的哪些數據。如果沒有該條件表達式,數據庫系統就會刪除表中的所有數據。

下面刪除s表中sno值為s1的記錄。

DELETE語句可以同時刪除多條記錄。

下面刪除s表中 city值為‘北京’的記錄。

DELETE語句中如果不加上“WHERE條件表達式”,數據庫系統會刪除指定表中的所有數據。

下面刪除s表中的所有記錄。

因為執行DELETE語句後,會將記錄從表中刪除。刪除過程中不會有任何提示,因此必須要特別小心。在條件允許的情況下,最好先用SELECT語句查詢準備刪除的記錄。這樣可以確認這些記錄確實是需要刪除的。

總結

到此這篇關於sql查詢語句教程之插入、更新和刪除數據的文章就介紹到這瞭,更多相關sql插入更新和刪除數據內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: