元数据:数据的数据,用以描述数据的信息也是数据,被称为元数据
[MySQL]获取元数据的方法
MySQL提供了以下三种方法用于获取数据库对象的元数据:
1)show语句
2)从INFORMATION_SCHEMA数据库里查询相关表(information_schema是一个虚拟数据库,并不物理存在,它储存数据的信息的数据库)
3)命令行程序,如mysqlshow, mysqldump
--用SHOW语句获取元数据
MySQL用show语句获取元数据是最常用的方法,下面提供了几种典型用法:
[sql]
show databases;  --列出所有数据库
show create database db_name;  --查看数据库的DDL
show tables; --列出默认数据库的所有表
show tables from db_name;  --列出指定数据库的所有表
show table status;  --查看表的描述性信息
show table status from db_name;
show create table tbl_name;  --查看表的DDL
show columns from tbl_name;  --查看列信息
show index from tbl_name;  --查看索引信息
有几种show语句还可以带有一条like 'pattern'字句,用来限制语句的输出范围,其中'pattern'允许包含'%'和'_'通配符,比如下面这条语句返回domaininfo表中以s开头的所有列:
[sql]
show columns from domaininfo like 's%';
像上面这张支持like字句的所有show都可以改写成一条where字句,如:
[sql]
show columns from domaininfo where field='sysdomain';
注:desc tbl_name和explain tbl_name的效果和show columns from tbl_name一致。
--从INFORMATION_SCHEMA数据库里查询相关表
INFORMATION_SCHEMA是MySQL自带的一个系统数据库,它里面存储了所有的元数据,通过select里面的相关表就可以获取你想要的元数据。和show语句相比,它比较麻烦,但它的好处是标准的SQL语句,更具有可移植性,且更灵活,可以通过各种表达式获取你真正需要的信息。
从命令行获取元数据
前面两种方法都必须得在MySQL命令行里执行,而mysqlshow和mysqldump提供了从OS命令行获取元数据库的方法,如:
[plain]
mysqlshow  --列出所有数据库
mysqlshow db_name  --列出给定数据库的所有表
mysqlshow db_name tbl_name  --列出给定数据库表的所有列
mysqlshow --keys db_name tbl_name  --列出索引信息
mysqlshow --status db_name  --列出数据库的描述性信息
mysqldump可以让你看到create table语句(就想show create table语句一样),如:
[sql]
mysqldump --no-data db_name [tbl_name] ...
*注意:在用mysqldump查看表结构时,一定要加上--no-data,否则你看到的将是数据库表里的数据。
--MySql数据库信息information_schema的查询使用
从MySQL 5开始, 你可以看到多了一个系统数据库information_schema . information_schema 存贮了其他所有数据库的信息。让我们来看看几个使用这个数据库的例子:
<!--more-->
1. 取得关于 information_schema的基本信息
information_schema是一个虚拟数据库,并不物理存在,在select的时候,从其他数据库获取相应的信息。
mysql> show databases;  
+--------------------+  
| Database           |  
+--------------------+  
| information_schema |  
| bugs               |  
| mysql              |  
| sugarcrm           |  
+--------------------+  
4 rows in set (0.00 sec)  
以下是information_schema数据库中的表.
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行的表
以下的语句可以查出超过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. 查询所有没有主键的表
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个最大表
mysql> SELECT concat(table_schema,'.',table_name) table_name,  
-> concat(round(data_length/(1024*1024),2),'M') data_length  
-> FROM information_schema.TABLES  
-> ORDER BY data_length DESC LIMIT 5;  
+--------------------+-------------+  
| table_name         | data_length |  
+--------------------+-------------+  
| bugs.attach_data   | 706.89M     |  
| bugs.longdescs     | 3.45M       |  
| bugs.bugs_activity | 1.45M       |  
| bugs.series_data   | 0.75M       |  
| bugs.attachments   | 0.51M       |  
+--------------------+-------------+  
5 rows in set (0.05 sec)  

转载于:https://www.cnblogs.com/jimmyChou/p/4285631.html

元数据--MySQL获取元数据的方法相关推荐

  1. mysql 元数据获取_[MySQL] 获取元数据的步骤

    [MySQL] 获取元数据的方法 MySQL提供了以下三种方法用于获取数据库对象的元数据: 1)show语句 2)从INFORMATION_SCHEMA数据库里查询相关表 3)命令行程序,如mysql ...

  2. Mybatis + mysql获取元数据时出现问题以及解决

    今天做mybatis配置文件,希望通过mybatis方法获得指定表的元数据,在mysql下,使用语句 show columns from user 这样类似的语句,由于表名需要通过参数获取,所以我就写 ...

  3. Oracle和Mysql获取uuid的方法对比

    场景:orm框架用mybatis,需要往数据库新增一条数据,用Oracle和mysql数据库分别需要怎么实现? mysql方法,用mysql提供的uuid函数 <insert id=" ...

  4. jdbc获取mysql第二行表信息_【奇技淫巧】MySQL另类方法获取元数据信息

    问:在进行MySQL注入时,我们通常是通过information_schema元数据来获取表名.字段名信息,从而读取相应数据.但是如果waf或其它过滤了information_schema关键字,那么 ...

  5. MySQL获取数据库元数据相关命令:DESC、SHOW、INFORMATION_SCHEMA、mysqlshow、mysqldump

    MySQL提供了多种获取数据库元数据(即有关数据库的信息与它里面的各种对象)的方式: DESC/EXPLAIN用来查看表信息 各种SHOW语句,例如SHOW DATABASES或SHOW TABLES ...

  6. mysql mdl 锁_详细分析mysql MDL元数据锁

    前言: 当你在MySQL中执行一条SQL时,语句并没有在你预期的时间内执行完成,这时候我们通常会登陆到MySQL数据库上查看是不是出了什么问题,通常会使用的一个命令就是 show processlis ...

  7. WCF技术剖析之二十八:自己动手获取元数据[附源代码下载]

    WCF技术剖析之二十八:自己动手获取元数据[附源代码下载] 原文:WCF技术剖析之二十八:自己动手获取元数据[附源代码下载] 元数据的发布方式决定了元数据的获取行为,WCF服务元数据架构体系通过Ser ...

  8. iOS音频---获取元数据

    iOS音频-获取元数据 参考文档: iOS音频播放 (四):AudioFile More-iOS开发中的音频相关内容总结 在Core Audio中使用AudioFileID指向一个audio file ...

  9. php mysql 表字段_php mysql获取表字段名称和字段信息的三种方法

    php mysql获取表字段名称和字段信息的三种方法 先给出本实例中使用的表的信息: 使用desc获取表字段信息 php代码如下: mysql_connect("localhost" ...

最新文章

  1. safari java插件故障_safari flash插件故障怎么办 mac safari flash插件故障解决方法
  2. 2021-07-15 深度学习服务器Linux终端网络训练training结果(顶会ECCV网络BiSeNet)
  3. rust大油井频率怎么用_数据量大怎么搞?当然是用这个了!
  4. Python中Numpy(2,numpy的基本操作(级联,维度转换,切分,副本))
  5. jboss4。0下mysql数据源的配置
  6. 无法显示验证码去掉html,如何去除验证码-模版风格-易通免费企业网站系统 - Powered by CmsEasy...
  7. pandas读取xlsx文件,编码问题
  8. 自己调用NTDLL函数
  9. XML Schema 简介
  10. 转载:CSDN mvc ef 的简单增删改查操作
  11. V5Shop网店系统更新 版本V8.30.0606 RC1
  12. 《R语言入门与数据分析》
  13. 图论3之图的最短路径算法
  14. 有些人 总是莫名其妙的得罪了
  15. 【聚类算法】MiniBatchKMeans算法
  16. vs2019 编译生成dll,lib,并做调用
  17. 旋转编码器怎么调零点?
  18. CAN光端机在西门子FC18/720消防主机海上风电厂之星型联网方式
  19. msn名字大集合(转)
  20. linux ac3165驱动下载,驱动程序无线网卡固件( 英特尔 3165 iwlwifi ) 仅适用于内核 4.1 +: 在内核 3.19的办法?...

热门文章

  1. exchange邮箱账号禁用之后 启用方法
  2. Nginx配置文件conf详解
  3. shell编程之 cut命令详解
  4. [转]Linux中常见目录简介
  5. GA遗传算法入门到掌握
  6. 财务人毕业三年薪资翻了三倍,学会数据分析竟然这么吃香
  7. 有一列数列,1,11,21,1211,111221,.........,
  8. python 小提高
  9. python游戏服务器搭建教程_游戏服务端pomelo安装配置
  10. js删除服务器上文件,js删除服务器文件