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

MySQL中的主键和rowid,看似简朴,着实有一些行使陷阱必要留意

发布时间:2019-10-10 18:54:25 所属栏目:编程 来源:杨建荣
导读:各人在MySQL中我们也许听到过rowid的观念,可是却很难去测试实践,不行停止会有一些迷惑,好比: 1)怎样感觉到rowid的存在 2)rowid和主键有什么关联相关 3)在主键的行使中存在哪些隐患 4)怎样来领略rowid的隐藏瓶颈并调试验证 本日要和各人一路接头这
副问题[/!--empirenews.page--]

MySQL中的主键和rowid,看似简朴,着实有一些行使陷阱必要留意

各人在MySQL中我们也许听到过rowid的观念,可是却很难去测试实践,不行停止会有一些迷惑,好比:

1)怎样感觉到rowid的存在

2)rowid和主键有什么关联相关

3)在主键的行使中存在哪些隐患

4)怎样来领略rowid的隐藏瓶颈并调试验证

本日要和各人一路接头这几个题目,测试的情形基于MySQL 5.7.19版本。

题目1:怎样感觉到rowid的存在

我们不妨通过一个案例来举办声名。

记得有一天统计备份数据的时辰,写了一条SQL,当看到执行功效时才发明SQL语句没有写完备,在完成统计事变之后,我筹备说明下这条SQL语句。

  1. mysql> select backup_date ,count(*) piece_no from redis_backup_result;  
  2. +-------------+----------+  
  3. | backup_date | piece_no |  
  4. +-------------+----------+  
  5. | 2018-08-14 | 40906 |  
  6. +-------------+----------+  
  7. 1 row in set (0.03 sec) 

按照营业特点,一天之内必定没有这么多的记录,明明差池,到底是那边出了题目呢。

本身细心看了下SQL,发明是没有加group by,我们随机查出10条数据。

  1. mysql> select backup_date from redis_backup_result limit 10;  
  2. +-------------+  
  3. | backup_date |  
  4. +-------------+  
  5. | 2018-08-14 |  
  6. | 2018-08-14 |  
  7. | 2018-08-14 |  
  8. | 2018-08-15 |  
  9. | 2018-08-15 |  
  10. | 2018-08-15 |  
  11. | 2018-08-15 |  
  12. | 2018-08-15 |  
  13. | 2018-08-15 |  
  14. | 2018-08-15 |  
  15. +-------------+  
  16. 10 rows in set (0.00 sec) 

在早期的版本中数据库参数sql_mode默以为空,不会校验这个部门,从语法角度来说,是应承的;可是到了高版本,好比5.7版本之后是不支持的,以是办理方案很简朴,在添加group by之后,功效就切合预期了。

  1. mysql> select backup_date ,count(*) piece_no from redis_backup_result group by backup_date;  
  2. +-------------+----------+  
  3. | backup_date | piece_no |  
  4. +-------------+----------+  
  5. | 2018-08-14 | 3 |  
  6. | 2018-08-15 | 121 |  
  7. | 2018-08-16 | 184 |  
  8. | 2018-08-17 | 3284 |  
  9. | 2018-08-18 | 7272 |  
  10. | 2018-08-19 | 7272 |  
  11. | 2018-08-20 | 7272 |  
  12. | 2018-08-21 | 7272 |  
  13. | 2018-08-22 | 8226 |  
  14. +-------------+----------+  
  15. 9 rows in set (0.06 sec) 

可是较量好奇这个理会的逻辑,看起来是SQL理会了第一行,然后输出了count(*)的操纵,显然这是从执行打算中无法获得的信息。

我们换个思绪,可以看到这个表有4万多条的记录。

  1. mysql> select count(*)from redis_backup_result;  
  2. +----------+  
  3. | count(*) |  
  4. +----------+  
  5. | 40944 |  
  6. +----------+  
  7. 1 row in set (0.01 sec) 

为了验证,我们可以行使_rowid的方法来做起源的验证。

InnoDB表中在没有默认主键的环境下会天生一个6字节空间的自动增添主键,可以用select _rowid from table来查询,如下:

  1. mysql> select _rowid from redis_backup_result limit 5;  
  2. +--------+  
  3. | _rowid |  
  4. +--------+  
  5. | 117 |  
  6. | 118 |  
  7. | 119 |  
  8. | 120 |  
  9. | 121 |  
  10. +--------+  
  11. 5 rows in set (0.00 sec) 

(编辑:河北网)

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

热点阅读