掌握mysql隐藏字段(rowid)什么时候是可见的

掌握mysql隐藏字段(rowid)什么时候是可见的

相关免费学习推荐:mysql视频教程

在这里插入图片描述

通过我自己的一番实战,可以确定的是,只要创建表,这个rowid一定是存在的,唯一区别就是显示和隐士的区别,也就是是否可以通过select _rowid from table查询出来那么问题来了,哪些情况下rowid是显示的?1 、当表中有主键并且是数值型的时候才是显示的2、当表中没有主键的时候,但是表中有唯一非空并且是数值型的时候才是显示的接下来,创建表来实战看下,是否是这样的

登录后复制

先创建一个带有主键并且是数值型的表create table  z1(id bigint(20) primary key )engine=innodb;

登录后复制

在这里插入图片描述

再创建一个带有主键不是数值型的表(虽然业务不会这样创建,只是为了证明rowid)create table  z2(name varchar(20) primary key )engine=innodb;

登录后复制

在这里插入图片描述

再创建一个没有主键但是有唯一键并且是数值型非空的表create table z3(    name int(11) not null,    unique(name))engine=innodb charset=utf8

登录后复制

在这里插入图片描述

此时再创建一个没有主键,并且有唯一键,但是可以为空或者不是数值型的表create table z4(   name varchar(11) not null,   unique(name))engine=innodb charset=utf8;create table z5(   name int(11) ,   unique(name))engine=innodb charset=utf8;

登录后复制

在这里插入图片描述
在这里插入图片描述

再来看看官网咋说的,再理解下官网连接:https://dev.mysql.com/doc/refman/5.7/en/create-index.htmlIf a table has a PRIMARY KEY or UNIQUE NOT NULL index that consists of a single column that has an integer type, you can use _rowid to refer to the indexed column in SELECT statements, as follows:_rowid refers to the PRIMARY KEY column if there is a PRIMARY KEY consisting of a single integer column. If there is a PRIMARY KEY but it does not consist of a single integer column, _rowid cannot be used.Otherwise, _rowid refers to the column in the first UNIQUE NOT NULL index if that index consists of a single integer column. If the first UNIQUE NOT NULL index does not consist of a single integer column, _rowid cannot be used.

登录后复制

此时我再创建一个表,表中只有一个字段,并且是字符串类型的,看下生成的隐式rowid,达到最大值会发生什么?(注意此时底层会默认生成一个6字节的指针,最大值为2^48 次幂)

登录后复制

在这里插入图片描述

此时用gdb工具让rowid达到最大值再插入看看会怎么样?     答:先找到mysqld的进程pid,命令      ps aux | grep mysqld     gdb -p 你的mysql的pid -ex 'p dict_sys->row_id=1' -batch

登录后复制

在这里插入图片描述
在这里插入图片描述

可以看到此时插入了3条数据

登录后复制

在这里插入图片描述

这个时候把rowid变为2^48次幂之后,再插入看下效果gdb -p 29410 -ex 'p dict_sys->row_id=281474976710656' -batch

登录后复制

在这里插入图片描述

此时再插入三条数据,此时a1 a2被覆盖了,所以在不满足上述二种情况的时候,生成的隐式rowid在用尽之后,之前的记录会被覆盖,所以创建表一定要有主键id,避免发生覆盖,虽然概率比较低,这个只是用主键的其中一个原因哈

登录后复制

在这里插入图片描述

所以综上所述:看我xmind那个总结,自己再理解消化下吧。

登录后复制

以上就是掌握mysql隐藏字段(rowid)什么时候是可见的的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1736866.html

(0)
上一篇 2025年2月19日 21:11:03
下一篇 2025年2月19日 21:11:25

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 成品wordpress进入网站 wordpress成品网站永久免费版进入

    本文介绍了获取WordPress成品网站永久免费版的多种途径,包括:WordPress官方网站,提供软件下载、主题模板、插件扩展及教程;WordPress.com,提供免费托管服务,但功能有限;免费主题资源网站,如TemplateMonst…

    2025年3月29日
    100
  • wordpress成品网站入口免费登录2025

    本文介绍了多种免费搭建WordPress网站的方法,主要包括两种途径:一是利用WordPress.org下载程序,结合官方主题库和插件自行搭建;二是借助WordPress.com的免费托管服务快速建站。此外,文章还推荐了TemplateMo…

    2025年3月29日
    100
  • Linux服务器上LNMP性能监控方法

    本文介绍几种在Linux服务器上监控LNMP(Linux, Nginx, MySQL, PHP)性能的方法和工具,助您确保服务器稳定运行。 一、Nginx监控 内置模块ngx_http_stub_status_module: 启用该模块后,…

    2025年3月29日
    100
  • Linux strings命令在不同文件格式中的表现

    linux strings 命令详解:从二进制文件中提取可打印字符串 strings 命令是 Linux 系统中一个强大的工具,用于从各种类型的文件中提取可打印的字符串。它能够帮助我们分析二进制文件,提取有用的信息。 下文将探讨 strin…

    2025年3月28日
    100
  • LNMP环境下如何进行故障排查

    LNMP (Linux, Nginx, MySQL, PHP) 环境故障排查指南: 第一步:确定问题 仔细记录故障现象,包括时间、受影响服务、用户反馈等细节信息,为后续排查提供依据。 第二步:检查系统资源 使用系统监控工具,检查CPU、内存…

    2025年3月28日
    100
  • Linux LAMP中MySQL如何备份数据

    在Linux LAMP架构中,定期备份MySQL数据库至关重要,这能有效保障数据安全和可恢复性。本文介绍几种常用的MySQL数据库备份方法: 方法一:利用mysqldump工具 mysqldump是MySQL自带的强大备份工具,支持对整个数…

    2025年3月28日
    100
  • Linux系统中LNMP日志管理技巧

    Linux系统中,LNMP(Linux、Nginx、MySQL、PHP)架构的日志管理至关重要,它直接关系到系统的稳定性和安全性。本文提供一些实用技巧,帮助你优化LNMP环境下的日志管理。 高效日志管理策略 日志轮转 (Log Rotati…

    2025年3月28日
    100
  • 如何通过日志预防Linux系统攻击

    日志分析是Linux系统安全防护的关键策略。本文将阐述如何通过日志记录、分析和响应来有效抵御潜在攻击。 一、启用并优化日志记录 全面启用日志功能: 确保所有核心服务和应用(SSH、Apache/Nginx、MySQL/PostgreSQL等…

    2025年3月28日
    100
  • 如何在LNMP中实现自动备份

    本文介绍如何在LNMP环境下轻松实现网站及数据库的自动备份。 我们将探讨几种方法,助您保障数据安全。 方法一:利用LNMP自带备份脚本 许多LNMP一键安装包都包含备份脚本(例如backup.sh,通常位于/root/lnmp1.6/too…

    2025年3月28日
    100
  • Linux日志中CPU使用率高的原因

    Linux系统日志通常不会直接指出CPU占用率过高的原因,但它们是诊断问题的关键线索。本文列举了导致CPU负载过高的常见因素,并讲解如何利用日志文件及其他工具进行排查和解决。 进程负载过高: 使用top或htop命令实时监控CPU资源占用情…

    2025年3月28日
    100

发表回复

登录后才能评论