掌握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.html If 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)什么时候是可见的的详细内容。更多信息请关注PHP中文网其他相关文章!
热AI工具
Undress AI Tool
免费脱衣服图片
Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片
AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。
Clothoff.io
AI脱衣机
Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!
热门文章
热工具
记事本++7.3.1
好用且免费的代码编辑器
SublimeText3汉化版
中文版,非常好用
禅工作室 13.0.1
功能强大的PHP集成开发环境
Dreamweaver CS6
视觉化网页开发工具
SublimeText3 Mac版
神级代码编辑软件(SublimeText3)
热门话题
实施交易和了解MySQL中的酸性
Jul 08, 2025 am 02:50 AM
MySQL支持事务处理,使用InnoDB存储引擎可确保数据一致性和完整性。1.事务是一组SQL操作,要么全部成功,要么全部失败回滚;2.ACID属性包括原子性、一致性、隔离性和持久性;3.手动控制事务的语句为STARTTRANSACTION、COMMIT和ROLLBACK;4.四种隔离级别包括读未提交、读已提交、可重复读和串行化;5.正确使用事务需注意避免长时间运行、关闭自动提交、合理处理锁及异常。通过这些机制,MySQL可实现高可靠与并发控制。
处理MySQL中的角色集和校正问题
Jul 08, 2025 am 02:51 AM
字符集和排序规则问题常见于跨平台迁移或多人开发时,导致乱码或查询不一致。核心解决方法有三:一要检查并统一数据库、表、字段的字符集为utf8mb4,通过SHOWCREATEDATABASE/TABLE查看,用ALTER语句修改;二要在客户端连接时指定utf8mb4字符集,在连接参数或执行SETNAMES中设置;三要合理选择排序规则,推荐使用utf8mb4_unicode_ci以确保比较和排序准确性,并在建库建表时指定或通过ALTER修改。
使用命令行客户端连接到MySQL数据库
Jul 07, 2025 am 01:50 AM
连接MySQL数据库最直接的方式是使用命令行客户端。首先输入mysql-u用户名-p并正确输入密码即可进入交互式界面;若连接远程数据库,需添加-h参数指定主机地址。其次,可直接在登录时切换到特定数据库或执行SQL文件,如mysql-u用户名-p数据库名或mysql-u用户名-p数据库名
使用MySQL 8中的常见表表达式(CTE)
Jul 12, 2025 am 02:23 AM
CTEs是MySQL8.0引入的特性,提升复杂查询的可读性与维护性。1.CTE是临时结果集,仅在当前查询中有效,结构清晰,支持重复引用;2.相比子查询,CTE更易读、可重用且支持递归;3.递归CTE可处理层级数据,如组织结构,需包含初始查询与递归部分;4.使用建议包括避免滥用、命名规范、关注性能及调试方法。
设计强大的MySQL数据库备份策略
Jul 08, 2025 am 02:45 AM
要设计一个靠谱的MySQL备份方案,1.首先明确RTO和RPO指标,根据业务可接受的停机时间和数据丢失范围确定备份频率与方式;2.采用混合备份策略,结合逻辑备份(如mysqldump)、物理备份(如PerconaXtraBackup)和二进制日志(binlog),实现快速恢复与最小数据丢失;3.定期测试恢复流程,确保备份有效性并熟悉恢复操作;4.注重存储安全,包括异地存储、加密保护、版本保留策略及备份任务监控。
MySQL查询性能优化的策略
Jul 13, 2025 am 01:45 AM
MySQL查询性能优化需从核心点入手,包括合理使用索引、优化SQL语句、表结构设计与分区策略、利用缓存及监控工具。1.合理使用索引:在常用查询字段上建索引,避免全表扫描,注意组合索引顺序,不低选择性字段加索引,避免冗余索引。2.优化SQL查询:避免SELECT*,不在WHERE中用函数,减少子查询嵌套,优化分页查询方式。3.表结构设计与分区:根据读写场景选择范式或反范式,选用合适字段类型,定期清理数据,大表考虑水平分表或按时间分区。4.利用缓存与监控:使用Redis缓存减轻数据库压力,开启慢查询
优化MySQL中的复杂加入操作
Jul 09, 2025 am 01:26 AM
TooptimizecomplexJOINoperationsinMySQL,followfourkeysteps:1)EnsureproperindexingonbothsidesofJOINcolumns,especiallyusingcompositeindexesformulti-columnjoinsandavoidinglargeVARCHARindexes;2)ReducedataearlybyfilteringwithWHEREclausesandlimitingselected
用MySQL分析查询执行
Jul 12, 2025 am 02:07 AM
MySQL的EXPLAIN是用于分析查询执行计划的工具,通过在SELECT查询前加EXPLAIN可查看执行过程。1.主要字段包括id、select_type、table、type、key、Extra等;2.高效查询需关注type(如const、eq_ref为佳)、key(是否使用合适索引)和Extra(避免Usingfilesort、Usingtemporary);3.常见优化建议:避免对字段使用函数或模糊前导通配符、确保字段类型一致、合理设置连接字段索引、优化排序与分组操作,以提升性能并减少资


