本文整理自网络,侵删。
目录
- 前言
- 什么是元数据
- 参考文档地址
- 先说MySQL
- 再说Oracle
- 总结
前言
最近接到个任务是抽取mysql和Oracle的元数据,大致就是在库里把库、schema、表、字段、分区、索引、主键等信息抽取出来,然后导成excel。
因为刚开始接触元数据,对这个并不了解,就想借助一下万能的百度,结果百度了一圈全是告诉我sql,直接cv就行了。虽然得到了部分数据,但是查的哪个库,哪个表我是完全不清楚的,得到的数据也不是我想要的,只有自己去官网看文档来完成自己的任务。
授人以鱼不如授人以渔,把经验写出来,给跟我一样疑惑的小伙伴一个参考。
什么是元数据
百度百科:元数据(Metadata),又称中介数据、中继数据,为描述数据的数据(data about data),主要是描述数据属性(property)的信息,用来支持如指示存储位置、历史数据、资源查找、文件记录等功能。元数据算是一种电子式目录,为了达到编制目录的目的,必须在描述并收藏数据的内容或特色,进而达成协助数据检索的目的。都柏林核心集(Dublin Core Metadata Initiative,DCMI)是元数据的一种应用,是1995年2月由国际图书馆电脑中心(OCLC)和美国国家超级计算应用中心(National Center for Supercomputing Applications,NCSA)所联合赞助的研讨会,在邀请52位来自图书馆员、电脑专家,共同制定规格,创建一套描述网络上电子文件之特征。
元数据是关于数据的组织、数据域及其关系的信息,简言之,元数据就是关于数据的数据。
参考文档地址
mysql:https://docs.oracle.com/cd/E17952_01/index.html
Oracle:https://docs.oracle.com/en/database/oracle/oracle-database/index.html
先说MySQL
mysql的元数据都在information_schema
库中以视图的形式存在,只能看,不能修改。
进入文档后直接看information_schema
的介绍,里面详细介绍了每一个表和字段。
常用的查询mysql元数据sql
-- 数据库 SELECT `schema_name` 库名,`DEFAULT_CHARACTER_SET_NAME` 默认字符集 FROM `SCHEMATA` -- 表 SELECT `TABLE_NAME` 表名,`TABLE_COMMENT` 描述,`TABLE_TYPE` 表类型 FROM`TABLES` -- 字段 SELECT `TABLE_SCHEMA` 库名,`TABLE_NAME` 表名,`COLUMN_NAME` 字段名,`COLUMN_COMMENT` 字段描述,`DATA_TYPE` 字段类型,`CHARACTER_MAXIMUM_LENGTH` 长度,`IS_NULLABLE` 是否为空 FROM `COLUMNS` -- 分区 SELECT `TABLE_SCHEMA` 库名,`TABLE_NAME` 表名,`PARTITION_NAME` 分区名,`PARTITION_ORDINAL_POSITION` 分区编号,`PARTITION_EXPRESSION` 分区函数表达式 FROM `PARTITIONS` WHERE partition_name IS NOT NULL -- 视图 SELECT * FROM `VIEWS` -- 索引 SELECT * FROM STATISTICS -- 主键 SELECT * FROM `COLUMNS` WHERE COLUMN_KEY = 'PRI'
再说Oracle
Oracle里的元数据在静态数据字典视图。
相关阅读 >>
连接oracle数据库时报ora-12541tns无监听程序的图文解决教程
如何在springboot项目中使用oracle11g数据库
更多相关阅读请进入《oracle》频道 >>

数据库系统概念 第6版
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » MySQL和Oracle的元数据抽取实例分析
相关推荐
评论
管理员已关闭评论功能...