[MySQL] 获取元数据的方法
2013-10-15 11:12
225 查看
MySQL提供了以下三种方法用于获取数据库对象的元数据:
1)show语句
2)从INFORMATION_SCHEMA数据库里查询相关表
3)命令行程序,如mysqlshow, mysqldump
有几种show语句还可以带有一条like 'pattern'字句,用来限制语句的输出范围,其中'pattern'允许包含'%'和'_'通配符,比如下面这条语句返回domaininfo表中以s开头的所有列:
像上面这张支持like字句的所有show都可以改写成一条where字句,如:
注:desc tbl_name和explain tbl_name的效果和show columns from tbl_name一致。
mysqldump可以让你看到create table语句(就想show create table语句一样),如:
注意:在用mysqldump查看表结构时,一定要加上--no-data,否则你看到的将是数据库表里的数据。
1)show语句
2)从INFORMATION_SCHEMA数据库里查询相关表
3)命令行程序,如mysqlshow, mysqldump
用SHOW语句获取元数据
MySQL用show语句获取元数据是最常用的方法,下面提供了几种典型用法: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开头的所有列:
show columns from domaininfo like 's%';
像上面这张支持like字句的所有show都可以改写成一条where字句,如:
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命令行获取元数据库的方法,如: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语句一样),如:
mysqldump --no-data db_name [tbl_name] ...
注意:在用mysqldump查看表结构时,一定要加上--no-data,否则你看到的将是数据库表里的数据。
相关文章推荐
- MySQL提供了以下三种方法用于获取数据库对象的元数据:
- mysql获取所有分类的前n条记录的两种方法浅析
- mysql获取一个表中的下一个自增(id)值的方法
- “无法从http://XXX/XXX.svc?wsdl获取元数据”错误的解决方法
- MYSQL获取自增ID的四种方法(转)
- ^全^ 获取SQL SERVER2000/2005、MySql、Oracle元数据的SQL语句(2)
- mybatis的insert语句获取自增id的方法(mySQL)
- MYSQL获取自增ID的四种方法
- Mysql中 show table status 获取表信息的方法
- MySQL中按时间获取慢日志信息的方法
- hive的元数据存储在mysql后,报错的解决方法!
- mysql 实现行号的方法——如何获取当前记录所在行号
- Mysql获取自动增加的id的最大值的方法
- 批量获取mysql用户权限的方法
- MYSQL获取自增主键【4种方法】
- 数据库_MYSQL获取自增主键【4种方法】 ,推荐方法3
- (转载)php获取mysql版本的几种方法小结
- 获取MySQL的表中每个userid最后一条记录的方法
- PHP获取mysql数据表的字段名称和详细信息的方法
- MYSQL获取自增ID的四种方法