MySQL培訓(xùn)教程:MySQL插入、更新、刪除表中的記錄
最新學(xué)訊:近期OCP認(rèn)證正在報名中,因考試人員較多請盡快報名獲取最近考試時間,報名費用請聯(lián)系在線老師,甲骨文官方認(rèn)證,報名從速!
我要咨詢mysql培訓(xùn)教程:mysql插入、更新、刪除表中的記錄,數(shù)據(jù)庫通過插入、更新和刪除等方式來該表表中的記錄,其中insert語句實現(xiàn)插入數(shù)據(jù),update語句實現(xiàn)更新數(shù)據(jù),delete語句實現(xiàn)刪除數(shù)據(jù)
參考表person

插入數(shù)據(jù)
不指定字段名插入
mysql> insert into person values(1,'張三','男',1988);
Query OK, 1 row affected, 1 warning (0.03 sec)
insert into后面是表名,values后面是需要插入的數(shù)據(jù)
values中的數(shù)據(jù)必須與字段名相匹配,如第一字段為空值則輸入null,尾部可不輸入
需要注意的是,字符串?dāng)?shù)據(jù)必須用引號包裹
指定字段名插入
mysql> insert into person(id,name,sex,birth) values(6,'王芳','女',1992);
Query OK, 1 row affected, 1 warning (0.05 sec)
insert into 后面接表名和字段,此處的字段可調(diào)整位置
但一個必要條件是后面的values值必須與其字段對應(yīng)
同時插入多條數(shù)據(jù)
mysql> insert into person(id,name) values(8,'錢名'),(9,'章碩');
Query OK, 2 rows affected (0.04 sec)
Records: 2 Duplicates: 0 Warnings: 0
values后面用多個括號插入數(shù)據(jù),逗號隔開即可
至于插入的字段只需結(jié)合上面講的兩個例子使用
將查詢結(jié)果插入到表中
mysql> insert into person2(id,name,sex,birth) select * from person;
Query OK, 9 rows affected, 6 warnings (0.03 sec)
Records: 9 Duplicates: 0 Warnings: 6
這里要注意,插入的字段和表中的字段個數(shù)和數(shù)據(jù)類型必須一致,否則就會報錯
復(fù)制一張表
mysql> CREATE TABLE per AS SELECT * FROM person;
Query OK, 1 row affected (0.16 sec)
Records: 1 Duplicates: 0 Warnings: 0
更新數(shù)據(jù)
單字段更新
mysql> update person set birth=1998 where id=1;
Query OK, 1 row affected (0.03 sec)
Rows matched: 1 Changed: 1 Warnings: 0
update+表名代表要更新的表,set后面設(shè)置需要更新的內(nèi)容
where用作限制更新條件,后面接表達(dá)式,只要表達(dá)式為真便滿足條件
Tips:where 1也能代表真,即全部滿足
多字段更新
mysql> update person set name='小紅',sex='女' where id=3;
Query OK, 1 row affected (0.03 sec)
Rows matched: 1 Changed: 1 Warnings: 0
多字段更新只需要在set后面添加多個要修改的字段和數(shù)據(jù)即可,用逗號隔開
如果想更新所有記錄則無需加where
tips:使用update要特別小心,因為有可能多條記錄滿足where條件
最好是先查看一邊表,確定要更新的記錄
刪除字段
刪除指定記錄
mysql> delete from person where id=9;
Query OK, 1 row affected (0.02 sec)
刪除記錄也需要跟上where限定
tips:除非你非常確定where子句只會刪除你想要刪除的行
否則都應(yīng)該用select來確認(rèn)情況
刪除所有記錄
mysql> delete from person;
Query OK, 8 rows affected (0.03 sec)
在不跟where限定條件的情況下即可逐條刪除所有記錄
此外還有truncate table語句,它會刪除原來的表,再重新建立,效率更高
tips:這里刪除不會要任何提示,說刪就刪了,快的很
所以使用的時候要格外小心,最好先把數(shù)據(jù)備份
- 冉乃綱-老師CUUG金牌講師
- 冉老師 CUUG金牌講師 Oracle及RedHat高級講師、Unix/Linux 資深專家...[詳細(xì)了解老師]

- 陳衛(wèi)星-老師CUUG金牌講師
- 陳老師 CUUG金牌講師 精通Oracle管理、備份恢復(fù)、性能優(yōu)化 11年Ora...[詳細(xì)了解老師]
