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;