information_schema mysql

从MySQL 5开始, 你可以看到多了一个系统数据库information_schema . information_schema 存贮了其他所有数据库的信息。让我们来看看几个使用这个数据库的例子:

< !--more-->

1. 取得关于 information_schema的基本信息

information_schema是一个虚拟数据库,并不物理存在,在select的时候,从其他数据库获取相应的信息。

Java代码 
  1. mysql> show databases; 
  2. +--------------------+ 
  3. | Database           | 
  4. +--------------------+ 
  5. | information_schema | 
  6. | bugs               | 
  7. | mysql              | 
  8. | sugarcrm           | 
  9. +--------------------+ 
  10. 4 rows in set (0.00 sec) 
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| bugs               |
| mysql              |
| sugarcrm           |
+--------------------+
4 rows in set (0.00 sec)

以下是information_schema数据库中的表.

Java代码 
  1. mysql> use information_schema; 
  2. mysql> show tables; 
  3. +---------------------------------------+ 
  4. | Tables_in_information_schema          | 
  5. +---------------------------------------+ 
  6. | CHARACTER_SETS                        | 
  7. | COLLATIONS                            | 
  8. | COLLATION_CHARACTER_SET_APPLICABILITY | 
  9. | COLUMNS                               | 
  10. | COLUMN_PRIVILEGES                     | 
  11. | KEY_COLUMN_USAGE                      | 
  12. | PROFILING                             | 
  13. | ROUTINES                              | 
  14. | SCHEMATA                              | 
  15. | SCHEMA_PRIVILEGES                     | 
  16. | STATISTICS                            | 
  17. | TABLES                                | 
  18. | TABLE_CONSTRAINTS                     | 
  19. | TABLE_PRIVILEGES                      | 
  20. | TRIGGERS                              | 
  21. | USER_PRIVILEGES                       | 
  22. | VIEWS                                 | 
  23. +---------------------------------------+ 
  24. 17 rows in set (0.00 sec) 
mysql> use information_schema;
mysql> show tables;
+---------------------------------------+
| Tables_in_information_schema          |
+---------------------------------------+
| CHARACTER_SETS                        |
| COLLATIONS                            |
| COLLATION_CHARACTER_SET_APPLICABILITY |
| COLUMNS                               |
| COLUMN_PRIVILEGES                     |
| KEY_COLUMN_USAGE                      |
| PROFILING                             |
| ROUTINES                              |
| SCHEMATA                              |
| SCHEMA_PRIVILEGES                     |
| STATISTICS                            |
| TABLES                                |
| TABLE_CONSTRAINTS                     |
| TABLE_PRIVILEGES                      |
| TRIGGERS                              |
| USER_PRIVILEGES                       |
| VIEWS                                 |
+---------------------------------------+
17 rows in set (0.00 sec)

2. 查询表中数据超过1000行的表
Java代码 
  1. 以下的语句可以查出超过1000行数据的表 
  2.  
  3. mysql> select concat(table_schema,'.',table_name) as table_name,table_rows 
  4.     -> from information_schema.tables where table_rows > 1000 
  5.     -> order by table_rows desc; 
  6.  
  7. +----------------------------------+------------+ 
  8. | table_name                       | table_rows | 
  9. +----------------------------------+------------+ 
  10. | bugs.series_data                 |      52778
  11. | bugs.bugs_activity               |      26436
  12. | bugs.longdescs                   |      21473
  13. | bugs.email_setting               |       5370
  14. | bugs.attachments                 |       4714
  15. | bugs.attach_data                 |       4651
  16. | bugs.cc                          |       4031
  17. | bugs.bugs                        |       2190
  18. | bugs.namedqueries_link_in_footer |       1228
  19. +----------------------------------+------------+ 
  20. 9 rows in set (0.04 sec) 
以下的语句可以查出超过1000行数据的表

mysql> select concat(table_schema,'.',table_name) as table_name,table_rows
    -> from information_schema.tables where table_rows > 1000
    -> order by table_rows desc;

+----------------------------------+------------+
| table_name                       | table_rows |
+----------------------------------+------------+
| bugs.series_data                 |      52778 |
| bugs.bugs_activity               |      26436 |
| bugs.longdescs                   |      21473 |
| bugs.email_setting               |       5370 |
| bugs.attachments                 |       4714 |
| bugs.attach_data                 |       4651 |
| bugs.cc                          |       4031 |
| bugs.bugs                        |       2190 |
| bugs.namedqueries_link_in_footer |       1228 |
+----------------------------------+------------+
9 rows in set (0.04 sec)

3. 查询所有没有主键的表
Java代码 
  1. This example gives a list of all the tables without primary key. 
  2.  
  3. SELECT CONCAT(t.table_name,".",t.table_schema) as table_name 
  4. FROM information_schema.TABLES t 
  5. LEFT JOIN information_schema.TABLE_CONSTRAINTS tc 
  6. ON t.table_schema = tc.table_schema 
  7. AND t.table_name = tc.table_name 
  8. AND tc.constraint_type = 'PRIMARY KEY' 
  9. WHERE tc.constraint_name IS NULL 
  10. AND t.table_type = 'BASE TABLE'
This example gives a list of all the tables without primary key.

SELECT CONCAT(t.table_name,".",t.table_schema) as table_name
FROM information_schema.TABLES t
LEFT JOIN information_schema.TABLE_CONSTRAINTS tc
ON t.table_schema = tc.table_schema
AND t.table_name = tc.table_name
AND tc.constraint_type = 'PRIMARY KEY'
WHERE tc.constraint_name IS NULL
AND t.table_type = 'BASE TABLE';

4. 实现表的历史数据information_schema

Putting the MySQL information_schema to Use article implements a history database using the information schema. The first half of this article describes the requirements for the history database, and a generic design to implement it. The second half describes the stepwise construction of code-generator that creates the SQL to construct and load the history database. The code-generator is driven by the information schema and some features of the information schema are discussed in detail.

5. 查询5个最大表

Java代码 
  1. mysql> SELECT concat(table_schema,'.',table_name) table_name, 
  2.     -> concat(round(data_length/(1024*1024),2),'M') data_length 
  3.     -> FROM information_schema.TABLES 
  4.     -> ORDER BY data_length DESC LIMIT 5
  5.  
  6. +--------------------+-------------+ 
  7. | table_name         | data_length | 
  8. +--------------------+-------------+ 
  9. | bugs.attach_data   | 706.89M     | 
  10. | bugs.longdescs     | 3.45M       | 
  11. | bugs.bugs_activity | 1.45M       | 
  12. | bugs.series_data   | 0.75M       | 
  13. | bugs.attachments   | 0.51M       | 
  14. +--------------------+-------------+ 
  15. 5 rows in set (0.05 sec) 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕业设计,基于SpringBoot+Vue+MySQL开发的影城管理系统,源码+数据库+论文答辩+毕业论文+视频演示 随着现在网络的快速发展,网上管理系统也逐渐快速发展起来,网上管理模式很快融入到了许多生活之中,随之就产生了“小徐影城管理系统”,这样就让小徐影城管理系统更加方便简单。 对于本小徐影城管理系统的设计来说,系统开发主要是采用java语言技术,在整个系统的设计中应用MySQL数据库来完成数据存储,具体根据小徐影城管理系统的现状来进行开发的,具体根据现实的需求来实现小徐影城管理系统网络化的管理,各类信息有序地进行存储,进入小徐影城管理系统页面之后,方可开始操作主控界面,主要功能包括管理员:首页、个人中心、用户管理、电影类型管理、放映厅管理、电影信息管理、购票统计管理、系统管理、订单管理,用户前台;首页、电影信息、电影资讯、个人中心、后台管理、在线客服等功能。 本论文主要讲述了小徐影城管理系统开发背景,该系统它主要是对需求分析和功能需求做了介绍,并且对系统做了详细的测试和总结。具体从业务流程、数据库设计和系统结构等多方面的问题。望能利用先进的计算机技术和网络技术来改变目前的小徐影城管理系统状况,提高管理效率。 关键词:小徐影城管理系统;Spring Boot框架,MySQL数据库
### 回答1: 这是 MySQLinformation_schema 数据库,它包含关于数据库中的所有元数据信息,包括表、列和索引等。MySQL中的information_schema是一个元数据数据库,它包含有关MySQL服务器的信息。information_schema中包含许多表,这些表提供了关于MySQL服务器的各种信息,例如数据库,表,列,索引,用户,权限等。 在MySQL中,您可以使用以下命令访问information_schema数据库: ``` USE information_schema; ``` 然后,您可以使用SELECT语句从information_schema中的表中检索所需的信息。例如,以下命令将返回当前MySQL服务器上所有数据库的名称: ``` SELECT schema_name FROM schemata; ``` 如果您想查看有关MySQL中的其他表或列的信息,请查看MySQL官方文档或使用以下命令检索信息_schema中的所有表的列表: ``` SELECT table_name FROM tables WHERE table_schema = 'information_schema'; ``` ### 回答2: MySQL中的information_schema是一个虚拟的数据库,其中包含了关于MySQL服务器的元数据信息。它包含了多个表,用于存储关于数据库、表、列、用户和权限等信息的一些元数据。这些元数据可以通过查询information_schema中的表来进行获取。 information_schema中包含的表的具体信息如下: 1. CHARACTER_SETS:该表包含了MYSQL支持的字符集的信息。 2. COLLATIONS:该表存储了MYSQL支持的排序规则。 3. COLUMNS:该表用于存储所有表和视图的列定义信息。 4. KEY_COLUMN_USAGE:该表存储了表、索引和外键中用到的列。 5. ROUTINES:该表存储了所有用户自定义函数和存储过程的信息。 6. SCHEMATA:该表包含了所有数据库的信息。 7. TABLES:该表用于存储所有表的信息。 8. USERS:该表存储了所有MySQL用户的信息,包括用户名、主机等。 除了上述表之外,information_schema中还包含了一些其他表,如VIEW_TABLE_USAGE、VIEW_ROUTINE_USAGE等,这些表也都提供了有关数据库和表的额外信息。 information_schema的作用非常重要,可以通过它查询到的元数据信息帮助我们更好地了解数据库中的结构和关系,从而更好的进行数据管理和数据操作。 ### 回答3: MySQL中的information_schema是一个系统数据库,它用于存储数据库中所有元数据的信息。元数据是关于数据库对象(表、列、索引等)的元信息,而information_schema中包含了这些元数据的集合,是MySQL中非常重要的数据库之一。 information_schema中包含许多数据表和视图,每个数据表或视图对应着一个元数据信息的集合。其中最重要的是以下几个: 1.数据库(SCHEMATA):包含数据库信息,如数据库名、默认字符集等; 2.表(TABLES):包含表的信息,如表名、表类型、创建时间等; 3.列(COLUMNS):包含表中所有列的信息,如列名、数据类型、长度等; 4.索引(STATISTICS):包含表的索引信息,如索引名、唯一性、索引类型等; 5.权限(USER_PRIVILEGES、SCHEMA_PRIVILEGES、TABLE_PRIVILEGES):包含数据库、表、列的权限信息。 除了上述常用的数据表和视图之外,还有一些其他的数据表或视图,如ROUTINES、PARAMETERS和KEY_COLUMN_USAGE。这些元数据信息可以通过SQL语句进行查询和分析,常用于数据库开发和管理中。 总之,information_schemaMySQL中非常重要的数据库之一,它存储了所有关于数据库对象的元数据信息,是数据库开发和管理的重要工具。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值