DML语言

DML语言  (数据操作语言)

##插入

语法:

insert into 表名(字段名,...)

values(值1,...);

特点:

1、字段类型和值类型一致或兼容,而且一一对应


一  insert into beauty(id,name,sex,borndate,phone,photo,boyfriend_id)

values(13,'小明','男','1991-9-8','18978984562',null,2),

(14,'小海','男','1991-9-8','18978984562',null,1)...;

二  insert into beauty

set id=19,name='小王',phone='1654';

方式一支持插入多行, 并且支持子查询


2、可以为空的字段,可以不用插入值,或用null填充

3、不可以为空的字段,必须插入值

4、字段个数和值的个数必须一致

5、字段可以省略,但默认所有字段,并且顺序和表中的存储顺序一致


###修改

修改单表语法:

update 表名 set 列=新值,列=新值...

【where 筛选条件】

案例1. update beauty set phone='123656498'

where name like ‘&军’;

修改多表语法:

update 表1 别名1,表2 别名2

set 列=新值,列=新值

where 连接条件

and 筛选条件;

案例:update boys bo

inner join beauty b on bo.id=b.boyfriend_id

set b.phone='114'

where bo.boyname="张无忌’; sql 199语法


###删除

方式1:delete语句

1.单表的删除:

delete from 表名 【where 筛选条件】

案例: delete from beauty where phone like '%9‘;

多表的删除:

sql92语法:

delete 别名1,别名2

from 表1 别名1,表2 别名2

where 连接条件

and 筛选条件;

sql99语法:

delete 别名1,别名2 from 表1 别名

inner|left|right join 表2 别名

on 连接条件

【where 筛选条件】

案例:

delete b

from beauty b inner join boys bo on b.boyfriend_id=bo.id

where bo.boyname='张无忌';

方式2:truncate语句

truncate table 表名

两种方式的区别【面试题】

#1.truncate不能加where条件,而delete可以加where条件

#2.truncate的效率高一丢丢

#3.truncate 删除带自增长的列的表后,如果再插入数据,数据从1开始

#delete 删除带自增长列的表后,如果再插入数据,数据从上一次的断点处开始

#4.truncate删除不能回滚,delete删除可以回滚

#5.truncate 删除没有返回值,delete删除有返回值

测试题

#1. 运行以下脚本创建表my_employees

USE myemployees;

CREATE TABLE my_employees(

Id INT(10),

First_name VARCHAR(10),

Last_name VARCHAR(10),

Userid VARCHAR(10),

Salary DOUBLE(10,2)

);

CREATE TABLE users(

id INT,

userid VARCHAR(10),

department_id INT

);

#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,'Biri','Ben','Bbiri',1100),

(4,'Newman','Chad','Cnewman',750),

(5,'Ropeburn','Audrey','Aropebur',1550);

DELETE FROM my_employees;

#方式二:

INSERT INTO my_employees

SELECT 1,'patel','Ralph','Rpatel',895 UNION

SELECT 2,'Dancs','Betty','Bdancs',860 UNION

SELECT 3,'Biri','Ben','Bbiri',1100 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);

#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;

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容