MySQL---数据删除方法delete、truncate、drop的区别

  • delete、truncate、drop的用法

  1. MySQL 数据表中delete删除数据的通用语法:

       删除 students_tbl 表中 student_id 为3 的记录:
    delete from students_tbl where student_id=3;
  2.  MySQL 数据表中truncate删除数据的通用语法:

       删除 students_tbl 表中的所有记录:
    truncate table students_tbl
  3. MySQL 数据表中drop删除数据的通用语法:

       删除名为 students 的数据库:
    drop database students
  •  delete、truncate、drop的区别

  1.  truncate和 delete只删除数据不删除表的结构(定义) ,drop语句将删除表的数据以及结构
     
  2. delete是DML语句,操作会被放到 rollback segment中,事务提交后才生效,以便进行进行回滚操作(可恢复)。
    truncate、drop是DLL语句,操作立即生效,原数据不放到 rollback segment中,不能回滚(不可恢复)。
     
  3. delete操作之后表或索引所占的空间不会减少,truncate操作之后表和索引所占用的空间会恢复到初始大小,drop语句将表所占用的空间全部释放。
     
  4. 删除速度: delete  < truncate < drop ;

总的来说:
              删除表内部分数据用delete,删除表内所有数据并且保留表的结构用truncate,删除表或者库用drop  

猜你喜欢

转载自blog.csdn.net/young_foryou/article/details/86256674