MySQL部分用法及场景

常用插入语句

insert into
特点:重复则报错,不重复则插入。
insert ignore into
特点:重复则忽略,不重复则插入。
insert into … on duplicate key update
特点:重复则更新指定字段,不重复则插入
replace into
特点:重复则先删除再插入新记录,不重复则插入

使用场景

如果出现重复异常,希望捕获异常,则使用insert into

如果出现重复异常,希望保存旧纪录,忽略新纪录,则使用insert ignore into

如果出现重复异常,希望更新指定字段,则使用insert into … on duplicate key update

如果出现重复异常,希望删除旧记录,插入新记录,则使用replace into

常用删除语句

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

truncate (table)
特点:删除表数据,不删除表的结构,速度排第二,但不能与where一起使用
delete from
特点:删除表中的数据,不删除表结构,速度最慢,但可以与where连用,可以删除指定的行

使用场景

希望删除表结构时,用 drop;

希望保留表结构,但要删除所有记录时, 用 truncate;

希望保留表结构,但要删除部分记录时, 用 delete。

三种方式的区别

相同点

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

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值