mysql 中,如果一张表没有主键也没有索引,执行 delete 会进行怎么样的操作?

2019-02-14 10:08:18 +08:00
 yaoweber

例如: 表 1: id name addr 1 zhangsan xxx 2 lisi xxx 3 wangwu xxx

将进行 delete 操作: delete from 表 1 where id=3; 数据库会进行什么操作?

是全表扫描一列一列的对比?生成的 binlog 会是什么样呢?

4913 次点击
所在节点    MySQL
8 条回复
banxi1988
2019-02-14 10:35:25 +08:00
其实你没有设置主键,MySQL 内部也会维护一个跟主键类似的东西。
wd
2019-02-14 13:45:20 +08:00
全表扫描 一行一行比
keepmovingbuddy
2019-02-14 16:08:34 +08:00
用 explain 命令执行一下就知道数据库具体怎么执行你的命令了
yaoweber
2019-02-14 16:15:51 +08:00
@banxi1988 现在问题是我都不会走主键
yaoweber
2019-02-14 16:16:31 +08:00
@wd 一行一行对比没有毛病,但是已经定位到某一行,然后怎么比呢?
wd
2019-02-14 16:40:51 +08:00
@yaoweber #5 比你的 where 指定的那列呀
msg7086
2019-02-14 22:39:30 +08:00
已经定位到某一行了还比什么?直接删掉这行啊!
c4f36e5766583218
2019-02-22 18:57:21 +08:00
@yaoweber 你不是写了 where id=3 ?(读取一行判断 id=3,删除,继续下一行

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/534778

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX