概述

总结一下MySQL数据库查看无主键表的一些sql,一起来看看吧~

1、查看表主键信息

--查看表主键信息 SELECT t.TABLE_NAME, t.CONSTRAINT_TYPE, c.COLUMN_NAME, c.ORDINAL_POSITION FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS AS t, INFORMATION_SCHEMA.KEY_COLUMN_USAGE AS c WHERE t.TABLE_NAME = c.TABLE_NAME  AND t.CONSTRAINT_TYPE = 'PRIMARY KEY'  AND t.TABLE_NAME = '<TABLE_NAME>'  AND t.TABLE_SCHEMA = '<TABLE_SCHEMA>';
--查看无主键表SELECT table_schema, table_name,TABLE_ROWSFROM information_schema.tablesWHERE (table_schema, table_name) NOT IN (SELECT DISTINCT table_schema, table_nameFROM information_schema.columnsWHERE COLUMN_KEY = 'PRI')AND table_schema NOT IN ('sys', 'mysql', 'information_schema', 'performance_schema');

在Innodb存储引擎中,每张表都会有主键,数据按照主键顺序组织存放,该类表成为索引组织表 Index Ogranized Table

如果表定义时没有显示定义主键,则会按照以下方式选择或创建主键:

1) 先判断表中是否有"非空的唯一索引",如果有

如果仅有一条"非空唯一索引",则该索引为主键

如果有多条"非空唯一索引",根据索引索引的先后顺序,选择第一个定义的非空唯一索引为主键。

2) 如果表中无"非空唯一索引",则自动创建一个6字节大小的指针作为主键。

如果主键索引只有一个索引键,那么可以使用_rowid来显示主键,实验测试如下:

--删除测试表DROP TABLE IF EXISTS t1;​--创建测试表CREATE TABLE `t1` ( `id` int(11) NOT NULL, `c1` int(11) DEFAULT NULL, UNIQUE uni_id (id), INDEX idx_c1(c1)) ENGINE = InnoDB CHARSET = utf8;​--插入测试数据INSERT INTO t1 (id, c1) SELECT 1, 1;INSERT INTO t1 (id, c1) SELECT 2, 2;INSERT INTO t1 (id, c1) SELECT 4, 4;​--查看数据和_rowidSELECT *, _rowid FROM t1;

总结

更多相关文章

  1. 【Android】 保存图片到系统图库, 并立即显示在图库中
  2. 从数据库中获取浏览器书签信息(Android(安卓)Browser开发)
  3. Android中常用的框架(从GitHub开源库中代码量来排名)
  4. android 调用图库中选择的图片
  5. android中从图库中选取图片
  6. android中从图库中选取图片
  7. android中从图库中选取图片
  8. android中从图库中选取图片
  9. android中从图库中选取图片

随机推荐

  1. android通过蓝牙连接打印机实现格式化打
  2. Android adb的常用命令
  3. 在 ubuntu 下编译 android 找不到头文件
  4. ANDROID Porting系列二、配置一个新产品
  5. Android主题和样式系统篇(上)
  6. ADT-bundle(Android Development Tools)
  7. Android(安卓)-- 补间动画
  8. android 引入jni 的so库的方法
  9. Android中自定义SeekBar来控制音量,并与系
  10. android studio template模块开发