首頁 > 軟體

sql查詢語句教學之插入、更新和刪除資料範例

2022-06-06 14:00:52

前言

資料庫通過插入、更新和刪除等方式來改變表中的記錄。插入資料是向表中插入新的記錄,通過 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插入更新和刪除資料內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com