首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql的infull用法

MySQL中的INFORMATION_SCHEMA是一个特殊的数据库,它提供了关于MySQL服务器中所有其他数据库的元数据信息。您可能想问的是INFORMATION_SCHEMA中的TABLES表,它包含了关于数据库中所有表的信息。

基础概念

INFORMATION_SCHEMA.TABLES表包含了以下列:

  • TABLE_CATALOG:表的目录名称。
  • TABLE_SCHEMA:表所属的数据库名称。
  • TABLE_NAME:表的名称。
  • TABLE_TYPE:表的类型(例如BASE TABLE, VIEW)。
  • ENGINE:存储引擎名称。
  • VERSION:表的版本。
  • ROW_FORMAT:行格式。
  • TABLE_ROWS:表中的估计行数。
  • AVG_ROW_LENGTH:表中行的平均长度。
  • DATA_LENGTH:数据文件的长度。
  • MAX_DATA_LENGTH:最大数据长度。
  • INDEX_LENGTH:索引文件的长度。
  • DATA_FREE:数据文件中未使用的空间。
  • AUTO_INCREMENT:下一个自动递增的值。
  • CREATE_TIME:表的创建时间。
  • UPDATE_TIME:表数据的最后更新时间。
  • CHECK_TIME:表检查的时间。
  • TABLE_COLLATION:表的排序规则。
  • CHECKSUM:表的校验和。
  • CREATE_OPTIONS:创建表时的选项。
  • TABLE_COMMENT:表的注释。

相关优势

  • 元数据访问INFORMATION_SCHEMA提供了对数据库元数据的访问,这对于数据库管理和维护非常有用。
  • 安全性:通过限制对INFORMATION_SCHEMA的访问,可以控制用户对数据库结构的了解程度。
  • 跨数据库查询:可以在不切换数据库的情况下查询多个数据库的信息。

应用场景

  • 数据库审计:监控数据库结构的变化,如表的创建、修改和删除。
  • 性能监控:分析表的行数、数据长度等信息,以评估数据库性能。
  • 备份策略:确定哪些表需要备份,以及它们的大小和更新频率。

常见问题及解决方法

问题:查询INFORMATION_SCHEMA.TABLES时速度慢

原因:可能是因为查询涉及大量的数据,或者数据库服务器性能不足。

解决方法

  • 确保数据库服务器有足够的资源(CPU、内存、磁盘I/O)。
  • 使用索引优化查询,尽管INFORMATION_SCHEMA中的表通常不支持索引。
  • 限制查询返回的数据量,例如只查询特定的数据库或表。

示例代码

代码语言:txt
复制
SELECT TABLE_SCHEMA, TABLE_NAME, TABLE_TYPE, ENGINE, CREATE_TIME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_SCHEMA = 'your_database_name';

参考链接

请注意,INFORMATION_SCHEMA是MySQL特有的,不同数据库系统可能有类似的元数据访问机制,但语法和表结构可能会有所不同。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQLJOIN用法

数据库中JOIN称为连接,连接主要作用是根据两个或多个表中列之间关系,获取存在于不同表中数据。连接分为三类:内连接、外连接、全连接。...另外还有CROSS JOIN(笛卡尔积),个人认为如果要理解MySQL中JOIN各种连接,只需要理解笛卡尔积就足够了。...笛卡儿积 笛卡尔乘积是指在数学中,两个集合X和Y笛卡尓积(Cartesian product),又称直积,表示为X × Y,第一个对象是X成员而第二个对象是Y所有可能有序对其中一个成员。...下图解释了表t1和t2之间内连接操作: ? 内连接 LEFT JOIN 左连接(LEFT JOIN)含义就是求两个表交集外加左表剩下数据。...从笛卡尔积角度讲,就是先从笛卡尔积中挑出ON子句条件成立记录,然后加上左表中剩余记录: ? 执行结果 下图解释了表t1和t2之间左连接操作: ?

2.2K20
  • MySQLJOIN用法

    数据库中JOIN称为连接,连接主要作用是根据两个或多个表中列之间关系,获取存在于不同表中数据。连接分为三类:内连接、外连接、全连接。...另外还有CROSS JOIN(笛卡尔积),个人认为如果要理解MySQL中JOIN各种连接,只需要理解笛卡尔积就足够了。...下图解释了表t1和t2之间内连接操作: ? 内连接 5 LEFT JOIN 左连接(LEFT JOIN)含义就是求两个表交集外加左表剩下数据。...右连接 相关教程 笛卡尔乘积_百度百科 MySQL各种join | 雕刻時光 Join查询 | liucw's blog Mysql 连接使用 | 菜鸟教程 MySQLJOIN(一):用法...- 付大石 - 博客园 MySQLJOIN(二):JOIN原理 - 付大石 - 博客园 Cartesian product - Wikipedia

    3.3K20

    Mysqllimit用法

    Mysqllimit用法 强烈推介IDEA2020.2破解激活,IntelliJ...初始记录行偏移量是 0(而不是 1): 为了与 PostgreSQL 兼容,MySQL 也支持句法: LIMIT # OFFSET #。...Sql代码 mysql> SELECT * FROM table LIMIT 5,10; // 检索记录行 6-15    //为了检索从某一个偏移量到记录集结束所有的记录行,可以指定第二个参数为...mysql> SELECT * FROM table LIMIT 5,10; // 检索记录行 6-15 //为了检索从某一个偏移量到记录集结束所有的记录行,可以指定第二个参数为 -1: mysql...【引用,路人乙:Mysql中limit用法详解】 2、Mysql分页查询语句性能分析       MySql分页sql语句,如果和MSSQLTOP语法相比,那么MySQLLIMIT语法要显得优雅了许多

    2.7K30

    mysql临时表用法

    当处理较复杂大逻辑时,你可能偶尔需要运行很多查询获得一个大量数据子集,不是对整个表运行这些查询,而是让MySQL每次找出所需少数记录,将记录存到一个临时表可能更快些,然后多这些表运行查询。...这就是mysql临时表作用了 一:创建临时表 CREATE TEMPORARY TABLE tmp_table (      name VARCHAR(10) NOT NULL,      value...如果你声明Mysql临时表是一个HEAP表,MySQL也允许你指定在内存中创建它 CREATE TEMPORARY TABLE tmp_table (      name VARCHAR(10) NOT... NULL,      value INTEGER NOT NULL      ) TYPE = HEAP 因为HEAP表存储在内存中,你对它运行查询可能比磁盘上临时表快些。...然而,HEAP表与一般表有些不同,且有自身限制。详见MySQL参考手册。

    2.8K20

    Mysql中limit用法

    目录 目录 前言 limit语法 性能分析 优化 用id优化 用覆盖索引优化 总结 前言 日常开发中,我们使用mysql来实现分页功能时候,总是会用到mysqllimit语法.而怎么使用却很有讲究...因为limit 10000,10语法实际上是mysql查找到前10010条数据,之后丢弃前面的10000行,这个步骤其实是浪费掉....用覆盖索引优化 mysql查询完全命中索引时候,称为覆盖索引,是非常快,因为查询只需要在索引上进行查找,之后可以直接返回,而不用再回数据表拿数据.因此我们可以先查出索引ID,然后根据Id拿数据....总结 用mysql做大量数据分页确实是有难度,但是也有一些方法可以进行优化,需要结合业务场景多进行测试....联系邮箱:huyanshi2580@gmail.com 更多学习笔记见个人博客——>呼延十 var gitment = new Gitment({ id: 'Mysql中limit用法', //

    11.7K20

    MYSQL用法(十五) MySQL中FIND_IN_SET()用法

    FIND_IN_SET(str,strlist) 返回str在字符串集strlist中序号(任何参数是NULL则返回NULL,如果str没找到返回0,参数1包含","时工作异常) 例子: 查询表字段...+{id},' 使用上面的语句,可以查询出来 用FIND_IN_SET() 更简单 SELECT * FROM linkinfo WHERE FIND_IN_SET('1',pingid 原来以为mysql...可以进行这样查询----->(一) select id, list, name from table where 'daodao' IN (list); 注:1. table含有三个字段id:int..., list:varchar(255), name:varchar(255) 实际上这样是不行,这样只有当name是list中第一个元素时,查询才有效,否则都不到结果,即使'daodao'真的再list...为什么第一条不能取得正确结果,而第二条却能取得结果。

    2.9K30

    mysql @value := 用法

    背景 有这么一张表,记录名字和分数,现在需要按照成绩排名,存在并列名次情况 解决方法 思路:按照score从大到小排序,第一行数据就是第一名,第二行就是第二名......需要判断当前行score和上一行...Every derived table must have its own alias -- 派生出来表都要有一个别名   新增两列表,一列是当前排名curRank,一个是上条记录score值preScore...按照score倒序排列,即score最大一行,第一名一条记录; 2....扫描完所有的记录后得到上表 case函数只返回第一个符合条件值,剩下case部分将会被自动忽略。...当有score一样情况时,@preScore=score时,@curRank并没有做+1操作,所以就有了并列情况

    5.8K91

    mysql中not exists用法_not exists用法

    大家好,又见面了,我是你们朋友全栈君。...not exists是sql中一个语法,常用在子查询和主查询之间,用于条件判断,根据一个条件返回一个布尔值,从而来确定下一步操作如何进行,not exists也是exists或in对立面。...not exists 是exists对立面,所以要了解not exists用法,我们首先了解下exists、in区别和特点: exists : 强调是是否返回结果集,不要求知道返回什么, 比如:...,那么exists这个条件就算成立了,大家注意返回字段始终为1,如果改成“select 2 from grade where …”,那么返回字段就是2,这个数字没有意义。...1,2,3 from grade where …) in子句返回了三个字段,这是不正确,exists子句是允许,但in只允许有一个字段返回,在1,2,3中随便去了两个字段即可。

    8.8K20

    MySQL replace into 用法

    Mysql中REPLACE INTO用法,判断数据是否存在,如果不存在,则插入,如果存在,则先删除此行数据,然后插入新数据 MySQL replace into 用法 在向表中插入数据时候,经常遇到这样情况...MySQL 中实现这样逻辑有个简单方法: replace into replace into t(id, update_time) values(1, now()); 或 replace into ...如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新数据。 2. 否则,直接插入新数据。 要注意是:插入数据表必须有主键或者是唯一索引!...前两种形式用多些。其中 “into” 关键字可以省略,不过最好加上 “into”,这样意思更加直观。另外,对于那些没有给予值列,MySQL 将自动为这些列赋上默认值。...官方文档参见:https://dev.mysql.com/ 图片 首发链接:https://www.cnblogs.com/lingyejun/p/16884215.html

    1.7K10

    MYSQL用法(九) 索引用法

    MySQL只需一次检索就能够找出正确结果!在没有扫描数据文件任何一个记录情况下,MySQL就正确地找出了搜索目标记录!   ...type:连接操作类型。下面是MySQL文档关于ref连接类型说明:  对于每一种与另一个表中记录组合,MySQL将从当前表读取所有带有匹配索引值记录。...Key: 它显示了MySQL实际使用索引名字。如果它为空(或NULL),则MySQL不使用索引。 key_len: 索引中被使用部分长度,以字节计。...如果MySQL只使用索引中firstname部分,则key_len将是50。 ref: 它显示是列名字(或单词“const”),MySQL将根据这些列来选择行。...在本例中,MySQL根据三个常量选择行。 rows: MySQL所认为它在找到正确结果之前必须扫描记录数。显然,这里最理想数字就是1。

    3.1K20

    mysql中exists用法详解

    前言 在日常开发中,用mysql进行查询时候,有一个比较少见关键词exists,我们今天来学习了解一下这个 exists这个sql关键词用法,这样在工作中遇到一些特定业务场景就可以有更加多样化解决方案...,该条数据保留 4、如果内层表t2不满足查询条件,则返回false,则删除该条数据 5、最终将外层所有满足条件数据进行返回 ---- 贴个链接,mysql官方对于这个命令说明: https:...//dev.mysql.com/doc/refman/8.0/en/exists-and-not-exists-subqueries.html;喜欢看英文原版说明可以来这里看一下 使用案例 环境准备...mysql版本: 8.0.28 数据库表设计: 学生表: t_student CREATE TABLE `t_student` ( `id` int unsigned NOT NULL AUTO_INCREMENT...我们明白了一个道理:内层循环次数多少不会影响到外层次数,但是外层循环次数直接会影响到内层循环次数,外层循环每多一次,内层循环就需要多完整一次循环,所以我们优化目标其实就是使外层循环次数尽量少

    4.9K50
    领券