加入收藏 | 设为首页 | 会员中心 | 我要投稿 百客网 - 百科网 (https://www.baikewang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

数据库技术:MySQL删除表的三种方式(小结)分享

发布时间:2023-02-20 13:50:33 所属栏目:MySql教程 来源:
导读:  droptable

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

  例如删除user表:

  droptableuser;

  truncate(table)

  truncate是删除表数据,不删除表的结构,速度排第二,
  droptable
 
  drop是直接删除表信息,速度最快,但是无法找回数据
 
  例如删除user表:
 
  droptableuser;
 
  truncate(table)
 
  truncate是删除表数据,不删除表的结构,速度排第二,但不能与where一起使用
 
  例如删除user表:
 
  truncatetableuser;
 
  deletefrom
 
  delete是删除表中的数据,不删除表结构,速度最慢,但可以与where连用,可以删除指定的行
 
  例如删除user表的所有数据
 
  deletefromuser;
 
  删除user表的指定记录
 
  deletefromuserwhereuser_id=1;
 
  三种方式的区别
 
  相同点
 
  truncate和不带where子句的delete,drop都会删除表内的数据; drop,truncate都是DDL语句(数据定义语言),执行后会自动提交;
 
  不同点
 
  语句类型:delete语句是数据库操作语言(DML),truncate,drop是数据库定义语言(DDL); 效率:一般来说drop>truncate>delete; 是否删除表结构:truncate和delete只删除数据不删除表结构,truncate删除后将重建索引(新插入数据后id从0开始记起)mysql删除表,而delete不会删除索引(新插入的数据将在删除数据的索引后继续增加),drop语句将删除表的结构包括依赖的约束,触发器,索引等; 安全性:drop和truncate删除时不记录MySQL日志,不能回滚,delete删除会记录MySQL日志,可以回滚; 返回值:delete操作后返回删除的记录数,而truncate返回的是0或者-1(成功则返回0,失败返回-1);
 
  小知识
 
  delete与deletefrom区别
 
  如果只针对一张表进行删除,则效果一样;如果需要联合其他表,则需要使用from
 
  deletetb1fromtb1mwhereidin(selectidfromtb2);
 
  用法上述就是数据库技术:MySQL删除表的三种方式(小结)分享的全部内容,如果对大家有所用处且需要了解更多关于mysql数据库学习教程。
 

(编辑:百客网 - 百科网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!