千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:沈阳千锋IT培训  >  技术干货  >  为什么查询information_schema下的TABLES这么慢?

为什么查询information_schema下的TABLES这么慢?

来源:千锋教育
发布人:xqq
时间: 2023-10-19 07:37:52

一、为什么查询information_schema下的TABLES这么慢

一般有两个原因。1、是元数据太多,就比如你的例子总共七万多张表,information_schema在统计时需要挨个去show table status,需要花费的时间较长。2、是参数innodb_stats_on_metadata设置为on的情况下,具体说明参考官方文档,可以将其设置为off对比下效果。

优化INFORMATION_SCHEMA查询

尝试在子句中使用数据库和表名的常量查找值WHERE

您可以按如下方式利用此原则:

若要查找数据库或表,请使用计算结果为常量的表达式,例如文本值、返回常量的函数或标量子查询。避免使用非常量数据库名称查找值(或无查找值)的查询,因为它们需要扫描数据目录才能查找匹配的数据库目录名称。在数据库中,请避免使用非常量表名查找值(或无查找值)的查询,因为它们需要扫描数据库目录才能查找匹配的表文件。

此原则适用于下表中显示的表,下表显示了常量查找值使服务器能够避免目录扫描的列。例如,如果要从INFORMATION_SCHEMATABLES,在子句中使用常量查找值可以避免数据目录扫描。

延伸阅读:

二、数据库和 SQL 概念

数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它的产生距今已有六十多年。随着信息技术和市场的发展,数据库变得无处不在:它在电子商务、银行系统等众多领域都被广泛使用,且成为其系统的重要组成部分。

数据库用于记录数据,使用数据库记录数据可以表现出各种数据间的联系,也可以很方便地对所记录的数据进行增、删、改、查等操作。

结构化查询语言(Structured Query Language)简称 SQL,是上世纪 70 年代由 IBM 公司开发,用于对数据库进行操作的语言。更详细地说,SQL 是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统,同时也是数据库脚本文件的扩展名。

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

C语言中定义与声明的含义是什么?

2023-10-19

Oracle/MySQL数据库创建索引的原则是什么?

2023-10-19

java.sql.Date,java.sql.Time和java.sql.Timestamp什么区别?

2023-10-19

最新文章NEW

C++ 写即时通讯服务器用什么数据库比较合适?

2023-10-19

云数据库并发数和连接数是个怎样的关系?

2023-10-19

为什么有些低端云主机(1CPU,4G内存)也提供SQLServer,这大型数据库,能运行吗?

2023-10-19

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>