mysql中的DML语言(数据操作、操纵语言,增删查改)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/czh500/article/details/85279421

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删除可以回滚.

*/

猜你喜欢

转载自blog.csdn.net/czh500/article/details/85279421