DML语言 数据操作语言

DML语言

/*
数据操作语言:+

插入:insert
修改:update
删除:delete

*/

一、插入语句

/*
语法:

insert into 表名(列名,....)values(值1,....)

特点:

1.列数和值数必须一致

*/

1.插入方式一

案例1:插入的值的类型与列的类型一致或兼容
INSERT INTO beauty(ID,NAME,SEX,borndate,PHONE,PHOTO,boyfriend_id)
VALUES(13,'唐艺昕','女','1990-4-23','1898888888',NULL,2);
案例2:不可以为null的列必须插入值!!!可以为null的列如何插入值?
#方式一
INSERT INTO beauty(ID,NAME,SEX,borndate,PHONE,PHOTO,boyfriend_id)
VALUES(13,'唐艺昕','女','1990-4-23','1898888888',NULL,2); #值为null 插入值
#方式二
INSERT INTO beauty(ID,NAME,SEX,borndate,PHONE,PHOTO,boyfriend_id)
VALUES(14,'金星','女','1990-4-23','1898888888',NULL,2); #不添加列
案例3:列的顺序是否可以调换
INSERT INTO beauty(NAME,ID,SEX,PHONE)
VALUES('蒋欣',15,'女',1120);
案例4:可以省略列名,默认所有列,而且列的顺序和表中顺序一致
INSERT INTO beauty
VALUES(16,'关晓彤','女','1990-4-23','198820202',NULL,3);

2.插入方式二

/*
语法:

insert into 表名
set 列名=值,列名=值

*/

案例5:
INSERT INTO beauty
SET ID=17,`name`='张紫宁',`phone`=1511515;

3.两种方式比较

案例6:方式一 支持插入多行 方式二 不支持
INSERT INTO beauty
VALUES(19,'小黑','女','1990-4-23','123123123',NULL,3),
(18,'乃万','女','1990-4-23','123123123',NULL,3);
案例7:方式一支持 子查询 ,方式二不支持
INSERT INTO beauty(ID,NAME,PHONE)
SELECT 20,'jinx','18616312315';

二、修改语句

/*
1.修改单表记录

语法:
	update	表名
	set 列=新值,列=新值,......
	WHERE 筛选条件;

2.修改多表记录

语法:
sql92
	update 表1 别名,表2 别名
	set 列=值,...
	WHERE 连接条件
	and 筛选条件;
sql99
	update 表1 别名
	inner|left|right join 表2 别名
	on 连接条件
	set 列=值,...
	where 筛选条件

*/

1.修改单表记录

案例8:修改beauty表中jinx的姓名为金克丝
UPDATE beauty
SET NAME='金克丝'
WHERE ID=20;
案例9:修改boys中id为2的名称为黄子韬,魅力值为110
UPDATE BOYS
SET USERCP=110,BOYNAME='黄子韬'
WHERE ID=2;

2.修改多表记录

案例10:修改张无忌女朋友的手机号为114
UPDATE BOYS AS BO
INNER JOIN beauty AS BE 
ON BO.`id`=BE.`boyfriend_id`
SET BE.`phone`=114
WHERE BO.`boyName`='张无忌';
案例11:修改没有男朋友的女神的男朋友编号为2号
UPDATE beauty AS BE
LEFT JOIN boys AS BO
ON BE.`boyfriend_id`=BO.`id`
SET BE.`boyfriend_id`=2
WHERE BO.`id` IS NULL;

三、删除语句

/*
方式一: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 tabel 表名

*/

方式一:delete

案例12:删除手机号以9结尾的女神信息
DELETE FROM beauty WHERE phone LIKE'%9';
案例13:删除张无忌女朋友的信息
DELETE BE  #删除哪个表的内容,写哪个表的别名
FROM beauty AS BE
INNER JOIN boys AS BO
ON BE.`boyfriend_id`=BO.`id`
WHERE BO.`boyName`='张无忌';
案例14:删除黄晓明的信息以及他女朋友Angelababy的信息
DELETE BE,BO
FROM beauty AS BE
INNER JOIN boys AS BO
ON BE.`boyfriend_id`=BO.`id`
WHERE BE.`name`='Angelababy'
AND BO.`boyName`='黄晓明';

方式二:truncate

案例15:将男神信息删除
TRUNCATE TABLE BOYS;

DELETE PK TRUNCATE

/*

1.delete 可以加 where 条件,truncate不行
2.truncate删除,效率高
3.假如要删除的表中有自增长列,如果用delete删除,再插入数据的话,自增长列的值从断点(删除前的最大序号+1)开始
  而truncate删除后,再插入数据的话,自增长列的值从1开始。
4.truncate删除没有返回值(使用后,共0行受影响),delete有返回值
5.truncate删除不能回滚,delete删除可以回滚。

*/

四、练习

2. 显示表my_employees的结构
DESC my_employees;
3. 向my_employees表中插入下列数据

/*

ID	FIRST_NAME	LAST_NAME	USERID	SALARY
1	patel		Ralph		Rpatel	895
2	Dancs		Betty		Bdancs	860
3	Biri		Ben		Bbiri	1100
4	Newman		Chad		Cnewman	750
5	Ropeburn	Audrey		Aropebur	1550

*/

INSERT INTO my_employees
VALUES(1,'patel','Ralph','Rpatel',895),(2,'Dancs','Betty','Bdancs',860),
(3,'Dancs','Betty','Bdancs',860),
(4,'Newman','Chad','Cnewman',750),
(5,'Ropeburn','Audrey','Aropebur',1550);
#或
INSERT INTO my_employees
SELECT 1,'patel','Ralph','Rpatel',895 UNION
SELECT 2,'Dancs','Betty','Bdancs',860 UNION
SELECT 3,'Dancs','Betty','Bdancs',860 UNION
SELECT 4,'Newman','Chad','Cnewman',750 UNION
SELECT 5,'Ropeburn','Audrey','Aropebur',1550;
4. 向users表中插入数据

/*

1	Rpatel	10
2	Bdancs	10
3	Bbiri	20
4	Cnewman	30
5	Aropebur	40

*/

INSERT INTO users
VALUES(1,'Rpatel',10),
(2,'Bdancs',10),
(3,'Bbiri',20),
(4,'Cnewman',30),
(5,'Aropebur',40);
5.将3号员工的last_name修改为“drelxer”
UPDATE my_employees
SET LAST_NAME='drelxer'
WHERE ID=3;
6.将所有工资少于900的员工的工资修改为1000
UPDATE my_employees
SET Salary=1000
WHERE Salary<900;
7.将userid 为Bbiri的user表和my_employees表的记录全部删除
DELETE U,E
FROM USERS U
JOIN my_employees E
ON U.`userid`=E.`Userid`
WHERE U.`userid`='Bbiri';
8.删除所有数据
DELETE FROM my_employees;
DELETE FROM useRS;
9.检查所作的修正
SELECT * FROM my_employees;
SELECT * FROM USERS;
10.清空表my_employees
TRUNCATE TABLE my_employees;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值