mysql中的DML語言(資料操作、操縱語言,增刪查改)
mysql中的DML語言(資料操作、操縱語言,增刪查改)
下面我就直接po筆記和程式碼,程式碼中有具體的案例
#DML語言
/*
資料操作語言:
插入:insert
修改:update
刪除:delete
*/
#一、插入語句
#方式一:經典的插入
/*
語法:
insert into 表名(列名,...) values(值1,...);
*/
#方式二:
/*
語法:
insert into 表名
set 列名=值,列名=值,...
*/
#二、修改語句
/*
注意:字元型別和日期型別的值要用引號包起
來,引號可以是單引號,也可以是雙引號,推薦使用單引號,
數字型別的值不需要用引號包起來
1.修改單表的記錄★
語法:
update 表名
set 列=新值,列=新值,...
where 篩選條件;
2.修改多表的記錄【補充】
語法:
sql92語法:只支援內聯
update 表1 別名,表2 別名
set 列=值,...
where 連線條件
and 篩選條件;
sql99語法:
update 表1 別名
inner|left|right join 表2 別名
on 連線條件
set 列=值,...
where 篩選條件;
*/
#三、刪除語句
/*
方式一: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的用法,不能加where條件
語法:truncate table 表名;
TRUNCATE TABLE 表名 雖然也能刪除表中的資料,但是TRUNCATE TABLE是DDL(資料定義語言,所
以不能帶where條件),如果要根據條件來刪除表中的某些資料的話必須要使用delete(DML 資料操作語言)
*/
#注意:truncate不可以/不允許加where條件,所以truncate其實就是清空資料
#既然truncate不可以/不允許加where條件,那自然就不能做到多表的刪除
#delete和truncate的比較和區別【面試題★】
/*
1.delete 可以加where 條件,truncate不能加
2.truncate刪除,效率高一丟丟
3.假如要刪除的表中有自增長列,
如果用delete刪除後,再插入資料,自增長列的值從斷點開始,
而truncate刪除後,再插入資料,自增長列的值從1開始。
4.truncate刪除沒有返回值,delete刪除有返回值
5.truncate刪除不能回滾,delete刪除可以回滾.
*/
#DML語言
/*
資料操作語言:
插入:insert
修改:update
刪除:delete
*/
#一、插入語句
#方式一:經典的插入
/*
語法:
insert into 表名(列名,...) values(值1,...);
*/
#
USE girls;
#
SELECT * FROM beauty;
#1.插入的值的型別要與列的型別一致或相容
INSERT INTO beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id)
VALUES(13,'林志玲','女','1976-08-26','1378888888',NULL,3);
#2.不可以為null的列必須插入值。可以為null的列如何插入值?
#方式一:
INSERT INTO beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id)
VALUES(14,'劉亦菲','女','1989-06-08','13766666666',NULL,4);
#方式二:
INSERT INTO beauty(id,NAME,sex,phone)
VALUES(15,'楊冪','女','13666668888');
#3.列的順序是否可以調換
INSERT INTO beauty(NAME,sex,id,phone)
VALUES('趙麗穎','女',16,'15799999999');
#4.列數和值的個數必須一致
INSERT INTO beauty(NAME,sex,id,phone)
VALUES('關曉彤','女',17,'18966665555');
#5.可以省略列名,預設所有列,而且列的順序和表中列的順序一致
INSERT INTO beauty
VALUES(18,'古力娜扎','女','','13798206689',NULL,NULL);
#方式二:
/*
語法:
insert into 表名
set 列名=值,列名=值,...
*/
#
SELECT * FROM beauty;
#
INSERT INTO beauty SET id=26, `name`='謝娜', phone='13798666508';
#
INSERT INTO beauty SET id=27, `name`='宋慧喬',
phone='13722334455', photo=NULL;
#
INSERT INTO beauty SET id=28, NAME='安以軒', phone='15933668877',
photo=NULL, sex='女',borndate='1982-02-06', boyfriend_id=NULL;
#兩種方式的比較 ★
#1、方式一支援插入多行,方式二不支援
INSERT INTO beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id)
VALUES(29,'張天愛','女','1989-03-08','13655558888',NULL,1),
(30,'李嘉欣','女','1972-04-09','13699664433',NULL,3),
(31,'楊超越','女','1998-09-26','15791684679',NULL,NULL);
#
INSERT INTO beauty
VALUES(32,'湯唯','女','1985-11-06','13733225588',NULL,2),
(33,'韓雪','女','1985-09-27','13922668855',NULL,3),
(34,'楊紫','女','1992-05-16','13625694583',NULL,NULL);
#
INSERT INTO beauty(`NAME`, sex, id, phone, boyfriend_id)
VALUES('全智賢', NULL, 35, '15889776322', NULL),
('郭碧婷', '女', 36, '13689326355', 3),
('宋祖兒', NULL, 37, '13789896377', 2);
#2、方式一支援子查詢,方式二不支援
#插入常量
INSERT INTO beauty(id, NAME, phone) SELECT 38, '李沁', '15934567829';
#插入常量
INSERT INTO beauty(id, `NAME`, phone,`boyfriend_id`) SELECT 39, '戚薇', '15934565566', NULL;
#插入常量
INSERT INTO beauty(id, NAME, phone) SELECT 40, '佟麗婭', '13934563579' FROM boys LIMIT 0, 1;
#從其他表中查到的資料插入到beauty表中
INSERT INTO beauty(id, NAME, phone) SELECT id, boyname, usercp FROM boys WHERE id = 666;
#從其他表中查到的資料插入到beauty表中
INSERT INTO beauty(id, NAME, phone) SELECT id, boyname, usercp FROM boys WHERE id > 800;
#所以,推薦使用方式一,方式一使用的較多
#二、修改語句
/*
注意:字元型別和日期型別的值要用引號包起
來,引號可以是單引號,也可以是雙引號,推薦使用單引號,
數字型別的值不需要用引號包起來
1.修改單表的記錄★
語法:
update 表名
set 列=新值,列=新值,...
where 篩選條件;
2.修改多表的記錄【補充】
語法:
sql92語法:只支援內聯
update 表1 別名,表2 別名
set 列=值,...
where 連線條件
and 篩選條件;
sql99語法:
update 表1 別名
inner|left|right join 表2 別名
on 連線條件
set 列=值,...
where 篩選條件;
*/
#1.修改單表的記錄
#案例1:修改beauty表中姓劉的女神的電話為13766668888
UPDATE beauty SET phone = '13766668888' WHERE `name` LIKE '劉%';
#案例2:修改boys表中id號為666的名稱為周杰倫周董,魅力值1200
UPDATE boys SET boyname = '周杰倫周董', usercp = 1200 WHERE
id = 666;
#2.修改多表的記錄
#案例 1:修改張無忌的女朋友的手機號為116
UPDATE beauty b INNER JOIN boys bo ON b.`boyfriend_id` = bo.`id`
SET b.`phone` = 116 WHERE bo.`boyName` = '張無忌';
#案例2:修改沒有男朋友的女神的男朋友編號都為3號
UPDATE beauty b LEFT JOIN boys bo ON b.`boyfriend_id` = bo.`id`
SET b.`boyfriend_id` = 3
WHERE bo.`id` IS NULL;
#同時修改兩表中的資料
#案例3:修改男朋友是黃曉明的女神的電話為888,並且把男朋友名字修改為黃曉明教主
UPDATE beauty b LEFT JOIN boys bo ON b.`boyfriend_id` = bo.`id`
SET b.`phone` = 888, bo.`boyName` ='黃曉明教主'
WHERE bo.`id` IS NOT NULL
AND bo.`boyName` = '黃曉明';
#
SELECT * FROM boys;
#
SELECT * FROM beauty;
#三、刪除語句
/*
方式一: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的用法,不能加where條件
語法:truncate table 表名;
TRUNCATE TABLE 表名 雖然也能刪除表中的資料,但是TRUNCATE TABLE是DDL(資料定義語言,所
以不能帶where條件),如果要根據條件來刪除表中的某些資料的話必須要使用delete(DML 資料操作語言)
*/
#方式一:delete
#1.單表的刪除
#案例:刪除手機號以007結尾的女神資訊
DELETE FROM beauty WHERE phone LIKE '%007';
#
SELECT * FROM beauty;
#2.多表的刪除
#案例:刪除李晨的女朋友的資訊(只刪了beauty表中滿足條件的資料)
DELETE b FROM beauty b INNER JOIN boys bo
ON b.`boyfriend_id` = bo.`id`
WHERE bo.`boyName` = '李晨';
#案例:刪除李晨的女朋友的資訊(刪了beauty表和boys表中滿足條件的資料)
DELETE b, bo FROM beauty b INNER JOIN boys bo
ON b.`boyfriend_id` = bo.`id`
WHERE bo.`boyName` = '李晨';
#案例:刪除陳赫的資訊以及他女朋友的資訊
#(刪除2個表中滿足條件的資料,DELETE後面跟2個表的別名即可)
DELETE b, bo FROM beauty b INNER JOIN boys bo
ON b.`boyfriend_id` = bo.`id`
WHERE bo.`boyName` = '陳赫';
#方式二:truncate語句
#注意:truncate不可以/不允許加where條件,所以truncate其實就是清空資料
#既然truncate不可以/不允許加where條件,那自然就不能做到多表的刪除
#案例:將魅力值>1000的男神資訊刪除(使用truncate是做不到的,因為truncate不可以加where條件)
#
SELECT * FROM person;
#清空表
TRUNCATE TABLE person;
#刪除表中資料
DELETE FROM person;
#
INSERT INTO person(person.`pname`) VALUES('令狐沖'), ('韋小寶'), ('楊過');
#delete和truncate的比較和區別【面試題★】
/*
1.delete 可以加where 條件,truncate不能加
2.truncate刪除,效率高一丟丟
3.假如要刪除的表中有自增長列,
如果用delete刪除後,再插入資料,自增長列的值從斷點開始,
而truncate刪除後,再插入資料,自增長列的值從1開始。
4.truncate刪除沒有返回值,delete刪除有返回值
5.truncate刪除不能回滾,delete刪除可以回滾.
*/