zoukankan      html  css  js  c++  java
  • MySQL 删除表的三种方式

    1、drop table

    drop 是直接删除表信息,速度最快,但是无法找回数据

    例如删除 user 表:

    drop table user;

    2、truncate table

    truncate 是删除表数据,不删除表的结构,速度排第二,但不能与where一起使用

    例如删除 user 表:

    truncate table user;

    3、delete from

    delete 是删除表中的数据,不删除表结构,速度最慢,但可以与where连用,可以删除指定的行

    例如删除user表的所有数据

    delete from user;

    删除user表的指定记录

    delete from user where user_id = 1;

    三种方式的区别

    相同点

    truncate和不带where子句的delete,drop都会删除表内的数据;

    drop,truncate都是DDL语句(数据定义语言),执行后会自动提交;

    不同点

    语句类型:delete语句是数据库操作语言(DML),truncate,drop是数据库定义语言(DDL);

    效率:一般来说 drop > truncate> delete;

    是否删除表结构:truncate和delete 只删除数据不删除表结构,truncate 删除后将重建索引(新插入数据后id从0开始记起),而 delete不会删除索引 (新插入的数据将在删除数据的索引后继续增加),drop语句将删除表的结构包括依赖的约束,触发器,索引等;

    安全性:drop和truncate删除时不记录MySQL日志,不能回滚delete删除会记录MySQL日志,可以回滚

    返回值:delete 操作后返回删除的记录数,而 truncate 返回的是0或者-1(成功则返回0,失败返回-1);

    小知识

    delete 与 delete from 区别

    如果只针对一张表进行删除,则效果一样;如果需要联合其他表,则需要使用from

    delete tb1 from tb1 m where id in (select id from tb2);

    用法总结

    1. 希望删除表结构时,用 drop;
    2. 希望保留表结构,但要删除所有记录时, 用 truncate;
    3. 希望保留表结构,但要删除部分记录时, 用 delete。
  • 相关阅读:
    ifelse选择结构
    Chrome插件开发进阶
    java应用线上一次故障诊断分析
    阻止保存要求重新创建表的更改
    【设计模式系列】行为型模式之Mediator模式
    C#.NET第一阶段课件下载
    Unity Animation.CrossFade Animation.Play
    Unity Resources.Load
    Unity Transform
    VS Ctrl + Shift + Q
  • 原文地址:https://www.cnblogs.com/frankyou/p/14395004.html
Copyright © 2011-2022 走看看