🚀 优质资源分享 🚀
学习路线指引(点击解锁) | 知识定位 | 人群定位 |
---|---|---|
🧡 Python实战微信订餐小程序 🧡 | 进阶级 | 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。 |
💛Python量化交易实战💛 | 入门级 | 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统 |
在 MySQL 中,删除的方法总共有 3 种:delete、truncate、drop,而三者的用法和使用场景又完全不同,接下来我们具体来看。
1.delete
detele 可用于删除表的部分或所有数据,它的使用语法如下:
delete from table_name [where...] [order by...] [limit...]
PS:[] 中的命令为可选命令,可以被省略。
如果我们要删除学生表中数学成绩排名最高的前 3 位学生,可以使用以下 SQL:
delete from student order by math desc limit 3;
1.1 delete 实现原理
在 InnoDB 引擎中,delete 操作并不是真的把数据删除掉了,而是给数据打上删除标记,标记为删除状态,这一点我们可以通过将 MySQL 设置为非自动提交模式,来测试验证一下。
非自动提交模式的设置 SQL 如下:
set autocommit=0;
之后先将一个数据 delete 删除掉,然后再使用 ro