1. 程式人生 > >mysql中的DML語言(資料操作、操縱語言,增刪查改)

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刪除可以回滾.

*/