四时宝库

程序员的知识宝库

MySQL实战第45篇:单表删除你会了,那么多表怎么删除呢?

欢迎来到MySQL实战第45篇,修炼MySQL,不让这一天又过去了。

在实际工作中,多表删除也是非常重要的,下面以编写一个案例介绍并学习这个多表删除技术。

【表的构建】

create table grade

(

id bigint(20) not null auto_increment,

name varchar(8) not null,

primary key(id)

)engine=InnoDB auto_increment=4 default charset=utf8;

insert into grade values(1,"一年级");

INSERT INTO `grade` VALUES (2, '二年级');

INSERT INTO `grade` VALUES (3, '三年级');

cREATE TABLE `student` (

`id` bigint(20) NOT NULL AUTO_INCREMENT,

`grade_id` bigint(20) NOT NULL COMMENT '年纪id',

`name` varchar(8) DEFAULT NULL,

`sex` tinyint(2) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

INSERT INTO `student` VALUES (1, 1, '张三', 1);

INSERT INTO `student` VALUES (2, 2, '李四', 2);

【多表删除的案例学习】

1.把表student中哪些grade_id值在grade表里匹配的记录全部删除。

<1>delete student from student,grade where student.grade_id=grade.id;

<2>delete from student using student,grade where student.grade_id=grade.id;

2.删除所有没有在grade表中有年纪记录的学生

<1>delete student from student left join grade on student.grade_id=grade.id where grade.id is null;

<2>delete from student using student left join grade on grade.id=student.grade_id where grade.id is null;

【总结性学习】

1.删除表的用法辨析

<1>drop table 表名; drop将表格直接删除,没有办法找回

<2>truncate(table) 表名; truncate 删除表中的所有数据,不能与where一起使用

<3>delete from 表名(where条件); delete 删除表中的数据。

2.truncate 和delete的区别

<1>事务:truncate 是不可以rollback的,但是delete是可以rollback的;

原因:trunctate删除整表数据,delete是一行一行的删除,可以rollback

<2>效果:truncate删除后将重新水平线和索引(id从零开始),delete不会删除索引。

<3>truncate不能触发delete触发器。

<4>delete删除可以返回行数。

关注财务总监的数据分析,一起修炼MySQL,500篇能掌握它。

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言
    友情链接