一、DML語言 數據操作語言: 插入:insert 修改:update 刪除:delete 二、插入語句insert 2.1、方式一 語法:insert into 表名(欄位名,...) values(值,...); 特點: 1、要求值的類型和欄位的類型要一致或相容 2、欄位的個數和順序不一定與原始 ...
一、DML語言
數據操作語言:
插入:insert
修改:update
刪除:delete
二、插入語句insert
2.1、方式一
語法:insert into 表名(欄位名,...) values(值,...);
特點:
1、要求值的類型和欄位的類型要一致或相容
2、欄位的個數和順序不一定與原始表中的欄位個數和順序一致,但必須保證值和欄位一一對應
3、假如表中有可以為null的欄位,註意可以通過以下兩種方式插入null值
①欄位和值都省略
②欄位寫上,值使用null
4、欄位和值的個數必須一致
5、欄位名可以省略,預設所有列
註:這裡使用另外一個資料庫進行講解案例
案例1:插入的值的類型要與列的類型一致或相容
INSERT INTO beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id) VALUES(13,'唐藝昕','女','1990-4-23','1898888888',NULL,2);
案例2:列的順序可以調換
INSERT INTO beauty(NAME,sex,id,phone) VALUES('蔣欣','女',16,'110');
案例3:可以省略列名,預設所有列,而且列的順序和表中列的順序一致
INSERT INTO beauty VALUES(18,'張飛','男',NULL,'119',NULL,NULL);
2.2、方式二
語法: insert into 表名 set 列名=值,列名=值,...
示例:INSERT INTO beauty SET id=19,NAME='劉濤',phone='999';
2.3、兩種方式大pk
1、方式一支持插入多行,方式二不支持
2、方式一支持子查詢,方式二不支持
三、修改語句
3.1、語法
(1)修改單表的記錄★
update 表名 set 列=新值,列=新值,... where 篩選條件;
(2)修改多表的記錄【補充】
sql92語法:
update 表1 別名,表2 別名 set 列=值,... where 連接條件 and 篩選條件;
sql99語法:
update 表1 別名 inner|left|right join 表2 別名 on 連接條件 set 列=值,... where 篩選條件;
3.2、修改單表的記錄
案例1:修改beauty表中姓唐的女神的電話為13899888899
UPDATE beauty SET phone = '13899888899' WHERE NAME LIKE '唐%';
案例2:修改boys表中id好為2的名稱為張飛,魅力值 10
UPDATE boys SET boyname='張飛',usercp=10 WHERE id=2;
3.3、修改多表的記錄
案例 1:修改張無忌的女朋友的手機號為114
案例2:修改沒有男朋友的女神的男朋友編號都為2號
四、刪除語句
4.1、語法
方式一:delete
1、單表的刪除【★】
delete from 表名 where 篩選條件
2、多表的刪除【補充】
sql92語法:
delete 表1的別名,表2的別名 from 表1 別名,表2 別名 where 連接條件 and 篩選條件;
sql99語法:
delete 表1的別名,表2的別名 from 表1 別名 inner|left|right join 表2 別名 on 連接條件 where 篩選條件;
方式二:truncate
語法:truncate table 表名;
4.2、delete
(1)單表的刪除
案例:刪除手機號以9結尾的女神信息
DELETE FROM beauty WHERE phone LIKE '%9';
(2)多表的刪除
案例:刪除黃曉明的信息以及他女朋友的信息
DELETE b,bo FROM beauty b INNER JOIN boys bo ON b.`boyfriend_id`=bo.`id` WHERE bo.`boyName`='黃曉明';
4.3、truncate語句
案例:將魅力值>100的男神信息刪除
TRUNCATE TABLE boys ;
4.4、delete pk truncate
(1)delete 可以加where 條件,truncate不能加;
(2)truncate刪除,效率高一丟丟;
(3)假如要刪除的表中有自增長列,如果用delete刪除後,再插入數據,自增長列的值從斷點開始,而truncate刪除後,再插入數據,自增長列的值從1開始;
(4)truncate刪除沒有返回值,delete刪除有返回值;
(5)truncate刪除不能回滾,delete刪除可以回滾.。
關註公眾號:Java後端生活,乾貨文章第一時間送達!