如何在MySQL中获取元数据

MySQL提供了以下三种方法用于获取数据库对象的元数据:

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,否则你看到的将是数据库表里的数据。

查看本栏目更多精彩内容:http://www.bianceng.cnhttp://www.bianceng.cn/database/MySQL/

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索数据库
, 数据
, 语句
, show
, mysqldump
, from
, MySQL信息查看命令
show方法
mysql获取元数据、mysql 元数据、mysql 元数据表、hive 元数据 mysql、mysql 查询元数据,以便于您获取更多的相关知识。

时间: 2024-09-14 00:12:43

如何在MySQL中获取元数据的相关文章

如何在Sql2008中获取表字段属性和注释

  如何在Sql2008中获取表字段属性和注释? select b.[value] from sys.columns a left join sys.extended_properties b on a.object_id=b.major_id and a.column_id=b.minor_id inner join sysobjects c on a.column_id=c.id and a.[name]='列名' and c.[name]='表名' SELECT 表名=case when

如何在service中获取camera中的视频数据

问题描述 如何在service中获取camera中的视频数据 小弟是Android新手,最近遇到一点困难,困难具体如下,请各位大哥赐教: 我想在service中获取camera组件,然后把从camera中获取的数据通过 socket发送到电脑端. 现在主要的问题是不知道怎么获取camera中的数据,surfaceView貌似行不通 解决方案 用void onPreviewFrame(byte[] data, Camera camera),data就是预览图像的数据一般情况下是YUV格式. 解决方

android-如何在dialog中获取edittext的值

问题描述 如何在dialog中获取edittext的值 代码如下,这样获取edittext.gettext().tostring()值总为空,该怎么改呢? final View viewDialog=(View)getLayoutInflater().inflate(R.layout.ad_dialog,null); new AlertDialog.Builder(Ad_Delete.this).setTitle("请输入删除数量(不能大于现有本数)") .setView(getLay

传值-js中的值如何在jsp中获取

问题描述 js中的值如何在jsp中获取 解决方案 success回调里面直接组合添加到你的链接里面去就好了,还是原来你的页面上有添加评论的html,你需要给链接添加上ajax返回的shareid还是什么 解决方案二: 你是要在success里获得shareId后,把这个shareId放到的href里去吗? 如果是,很简单,你在js里用jquery拿到,然后设置的href属性. 解决方案三: request.getParameter("shareId") 解决方案四: 你 shareId

如何在ueditor中获取选中元素(比如DIV)的css/attr等

问题描述 如何在ueditor中获取选中元素(比如DIV)的css/attr等 我在ueditor下想获取编辑区内被选中的元素,读取它的某些属性(包括CSS或Attr)的设置,可用到var Width = UE.dom.domUtils.getStyle('width');时出错,并没有获取到这些值.请问如何解决?谢谢3Q 解决方案 参考 百度UEditor在线编辑器getStyle 获取元素element的某个样式值UE.dom.domUtils.getStyle(elementname) ?

请教如何在C#中获取本机的网络利用率

问题描述 如题~请教如何在C#中获取本机的网络利用率,就是获取系统资源管理器中的网络利用率 解决方案 解决方案二: 解决方案三:感谢,已经解决了~

eclipse rcp-eclipse RCP开发中如何在Activator中获取plugin.xml中配置的action

问题描述 eclipse RCP开发中如何在Activator中获取plugin.xml中配置的action action是在extensions里重写eclipse提供的标准扩展点:org.eclipse.ui.actionSets.想在Activator中获取此action对象并调用setEnable()方法,达到控制按钮的可用和禁用状态.望各位大神帮忙! 解决方案 目前我也不会,但是需要积分

mysql-百度地图从MySql中获取经纬度

问题描述 百度地图从MySql中获取经纬度 <%@ page contentType="text/html; charset=utf-8" %> <%@ page language="java" %> <%@ page import="com.mysql.jdbc.Driver" %> <%@ page import="java.sql.*" %> <% String dr

ip地址-如何在QQ2015中获取IP地址 2014也行

问题描述 如何在QQ2015中获取IP地址 2014也行 小弟十分想知道如何在当前版本中获取qq所在地的IP地址.听说网上有能根据qq查实际姓名等信息的原理是什么 解决方案 首先要和对方不断的聊天,然后打开命令提示符(开始,运行,输入cmd.或在开始菜单==>所有程序==>附件=>命令提示符)...然后输入一下命令 netstat -n 此时我们可以看到一栏IP地址: Active Connections Proto Local Address Foreign Address State