在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
在介绍mysql的多版本并发控制 本文我们就来重点讨论一下诸多隐藏列中的行标识
简单翻译一下,如果在表中存在主键或非空唯一索引,并且仅由一个整数类型的列构成,那么就可以使用 着重看一下文档中提到的几个关键字,主键、唯一索引、非空、单独一列、数值类型,接下来我们就要从这些角度入手,探究一下神秘的隐藏字段 1、存在主键先看设置了主键且是数值类型的情况,使用下面的语句建表: CREATE TABLE `table1` ( `id` bigint(20) NOT NULL PRIMARY KEY , `name` varchar(32) DEFAULT NULL ) ENGINE=InnoDB; 插入三条测试数据后,执行下面的查询语句,在 select *,_rowid from table1 查看执行结果, 可以看到在设置了主键,并且主键字段是数值类型的情况下, 回顾一下前面提到的文档中的几个关键字,分别对其进行分析。由于主键必定是非空字段,下面来看一下主键是非数值类型字段的情况,建表如下: CREATE TABLE `table2` ( `id` varchar(20) NOT NULL PRIMARY KEY , `name` varchar(32) DEFAULT NULL ) ENGINE=InnoDB; 在 2、无主键,存在唯一索引上面对两种类型的主键进行了测试后,接下来我们看一下当表中没有主键、但存在唯一索引的情况。首先测试非空唯一索引加在数值类型字段的情况,建表如下: CREATE TABLE `table3` ( `id` bigint(20) NOT NULL UNIQUE KEY, `name` varchar(32) ) ENGINE=InnoDB; 查询可以正常执行,并且 唯一索引与主键不同的是,唯一索引所在的字段可以为 CREATE TABLE `table4` ( `id` bigint(20) UNIQUE KEY, `name` varchar(32) ) ENGINE=InnoDB; 执行查询语句,在这种情况下,无法显式地查询到 和主键类似的,我们再对唯一索引被加在非数值类型的字段的情况进行测试。下面在建表时将唯一索引添加在字符类型的字段上,并添加非空约束: CREATE TABLE `table5` ( `id` bigint(20), `name` varchar(32) NOT NULL UNIQUE KEY ) ENGINE=InnoDB; 同样无法显示的查询到 针对上面三种情况的测试结果,可以得出结论,当没有主键、但存在唯一索引的情况下,只有该唯一索引被添加在数值类型的字段上,且该字段添加了非空约束时,才能够显式地查询到 3、存在联合主键或联合唯一索引在上面的测试中,我们都是将主键或唯一索引作用在单独的一列上,那么如果使用了联合主键或联合唯一索引时,结果会如何呢?还是先看一下官方文档中的说明:
简单来说就是,如果主键存在、且仅由数值类型的一列构成,那么 根据这一描述,我们测试一下联合主键的情况,下面将两列数值类型字段作为联合主键建表: CREATE TABLE `table6` ( `id` bigint(20) NOT NULL, `no` bigint(20) NOT NULL, `name` varchar(32), PRIMARY KEY(`id`,`no`) ) ENGINE=InnoDB; 执行结果无法显示的查询到 同样,这一理论也可以作用于唯一索引,如果非空唯一索引不是由单独一列构成,那么也无法直接查询得到 4、存在多个唯一索引在mysql中,每张表只能存在一个主键,但是可以存在多个唯一索引。那么如果同时存在多个符合规则的唯一索引,会引用哪个作为
简单翻译一下,如果表中的第一个非空唯一索引仅由一个整数类型字段构成,那么 在下面的表中,创建两个都符合规则的唯一索引: CREATE TABLE `table8_2` ( `id` bigint(20) NOT NULL, `no` bigint(20) NOT NULL, `name` varchar(32), UNIQUE KEY(no), UNIQUE KEY(id) ) ENGINE=InnoDB; 看一下执行查询语句的结果: 可以看到 那么,如果表中创建的第一个唯一索引不符合 CREATE TABLE `table9` ( `id` bigint(20) NOT NULL, `no` bigint(20) NOT NULL, `name` varchar(32), UNIQUE KEY `index1`(`id`,`no`), UNIQUE KEY `index2`(`id`) ) ENGINE=InnoDB; 进行查询,可以看到虽然存在一个单列的非空唯一索引,但是因为顺序选取的第一个不满足要求,因此仍然不能直接查询 如果将上面创建唯一索引的语句顺序调换,那么将可以正常显式的查询到 5、同时存在主键与唯一索引从上面的例子中,可以看到唯一索引的定义顺序会决定将哪一个索引应用 按照下面的语句创建两个表,只有创建主键和唯一索引的顺序不同: CREATE TABLE `table11` ( `id` bigint(20) NOT NULL, `no` bigint(20) NOT NULL, PRIMARY KEY(id), UNIQUE KEY(no) ) ENGINE=InnoDB; CREATE TABLE `table12` ( `id` bigint(20) NOT NULL, `no` bigint(20) NOT NULL, UNIQUE KEY(id), PRIMARY KEY(no) ) ENGINE=InnoDB; 查看运行结果: 可以得出结论,当同时存在符合条件的主键和唯一索引时,无论创建顺序如何, 6、无符合条件的主键与唯一索引上面,我们把能够直接通过 实际上, CREATE TABLE `table10` ( `id` bigint(20), `name` varchar(32) ) ENGINE=InnoDB; 首先,我们需要先查找到mysql的进程 ps -ef | grep mysqld 可以看到,mysql的进程 在开始动手前,还需要做一点铺垫, 在 接下来我们需要用到 gdb -p 2068 -ex 'p dict_sys->row_id=1' -batch 命令执行结果: 在空表中插入3行数据: INSERT INTO table10 VALUES (100000001, 'Hydra'); INSERT INTO table10 VALUES (100000002, 'Trunks'); INSERT INTO table10 VALUES (100000003, 'Susan'); 查看表中的数据,此时对应的 然后通过 gdb -p 2068 -ex 'p dict_sys->row_id=281474976710656' -batch 命令执行结果: 再向表中插入三条数据: INSERT INTO table10 VALUES (100000004, 'King'); INSERT INTO table10 VALUES (100000005, 'Queen'); INSERT INTO table10 VALUES (100000006, 'Jack'); 查看表中的全部数据,可以看到第一次插入的三条数据中,有两条数据被覆盖了: 为什么会出现数据覆盖的情况呢,我们对这一结果进行分析。首先,在第一次插入数据前 当手动设置 当出现相同 所以当表中的主键或唯一索引不满足我们前面提到的要求时,
到此这篇关于MySQL中的隐藏列的具体使用的文章就介绍到这了,更多相关MySQL 隐藏列内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论