ToB企服应用市场:ToB评测及商务社交产业平台

标题: 【小白专用】MySQL查询数据库所有表名及表结构其注释 [打印本页]

作者: 吴旭华    时间: 2024-6-23 19:14
标题: 【小白专用】MySQL查询数据库所有表名及表结构其注释
一、先了解下INFORMATION_SCHEMA
1、在MySQL中,把INFORMATION_SCHEMA看作是一个数据库,确切说是信息数据库。此中生存着关于MySQL服务器所维护的所有其他数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权 限等。在INFORMATION_SCHEMA中,有数个只读表。它们实际上是视图,而不是基本表,因此,你将无法看到与之相关的任何文件。
2、TABLES表:提供了关于数据库中的表的信息(包罗视图)。具体表述了某个表属于哪个schema,表类型,表引擎,创建时间等信息。是show tables from schemaname的效果取之此表。
3、COLUMNS表:提供了表中的列信息。具体表述了某张表的所有列以及每个列的信息。是show columns from schemaname.tablename的效果取之此表。
 
  1. #查询所有的数据库名称
  2. SELECT SCHEMA_NAME AS Database FROM INFORMATION_SCHEMA.SCHEMATA;
  3. #查询指定数据库下的所有表名(例如information_schema数据库下的所有表名)
  4. select table_name as name  from information_schema.TABLES where TABLE_SCHEMA='information_schema'
复制代码

查看ftp数据库内以oemp开头的所有的表名、表数据量、表备注、字段名称、字段类型、默认值、字段备注等;如果查整个数据库就把ftp后全删除。
  1.             string sql = $@"SELECT TABLE_NAME as TableName,
  2.                      column_name AS DbColumnName,
  3.                      CASE WHEN  left(COLUMN_TYPE,LOCATE('(',COLUMN_TYPE)-1)='' THEN COLUMN_TYPE ELSE  left(COLUMN_TYPE,LOCATE('(',COLUMN_TYPE)-1) END AS DataType,
  4.                      CAST(SUBSTRING(COLUMN_TYPE,LOCATE('(',COLUMN_TYPE)+1,LOCATE(')',COLUMN_TYPE)-LOCATE('(',COLUMN_TYPE)-1) AS signed) AS Length,
  5.                      column_default  AS  `DefaultValue`,
  6.                      column_comment  AS  `ColumnComment`,
  7.                      CASE WHEN COLUMN_KEY = 'PRI' THEN true ELSE false END AS `IsPrimaryKey`,
  8.                      CASE WHEN EXTRA='auto_increment' THEN true ELSE false END as IsIdentity,
  9.                      CASE WHEN is_nullable = 'YES' THEN true ELSE false END AS `IsNullable`
  10.                      FROM Information_schema.columns where TABLE_NAME='{tableName}' and  TABLE_SCHEMA=(select database()) ORDER BY TABLE_NAME";
复制代码

  1. SELECT  
  2.     T1.TABLE_COMMENT 表注释,
  3.     T1.TABLE_ROWS 表数据量,
  4.     T2.TABLE_NAME 表名,
  5.     T2.COLUMN_NAME 字段名,  
  6.     T2.COLUMN_TYPE 数据类型,  
  7.     T2.DATA_TYPE 字段类型,  
  8.     T2.CHARACTER_MAXIMUM_LENGTH 长度,  
  9.     T2.IS_NULLABLE 是否为空,  
  10.     T2.COLUMN_DEFAULT 默认值,  
  11.     T2.COLUMN_COMMENT 字段备注   
  12. FROM
  13.     INFORMATION_SCHEMA.TABLES T1
  14. LEFT JOIN
  15.     INFORMATION_SCHEMA.COLUMNS T2
  16. ON
  17.     T1.TABLE_NAME = T2.TABLE_NAME
  18. WHERE  
  19.     T1.TABLE_SCHEMA ='ftp'
  20. AND
  21.     T1.TABLE_NAME LIKE 'oemp%'
  22. ORDER BY
  23.     T1.TABLE_NAME;
复制代码



二、如何获取全部表名

基本的语句为
  1. SELECT table_name FROM information_schema.tables
复制代码
但是这个并不符合业务需求,由于这会返回全部的表名,而业务中需要限定是哪个数据库,并且,差别的业务大概会利用差别的表前缀,以是最好可以限定表前缀,并且需要展示表的注释,不然各人也不清楚表是属于哪个业务的。
以是,完备的SQL语句如下

  1. SELECT
  2.         TABLE_NAME,
  3.         TABLE_COMMENT
  4. FROM
  5.         information_schema.TABLES
  6. WHERE
  7.         TABLE_SCHEMA = 'TABLE_SCHEMA'
  8.         AND TABLE_NAME LIKE 'x_%'
  9.         AND TABLE_NAME NOT LIKE 'xx_exp%'
  10. ORDER BY
  11.         TABLE_NAME
复制代码

需要设置几个参数,并且已经按表名进行排序,TABLE_COMMENT 为表注释。
运行效果如下图





  1. 1、查看Mysql 数据库 "ori_data"下所有表的表名、表注释及其数据量
  2. SELECT
  3. TABLE_NAME 表名,TABLE_COMMENT 表注释,TABLE_ROWS 数据量
  4. FROM information_schema.tables
  5. WHERE TABLE_SCHEMA = 'ori_data'
  6. ORDER BY TABLE_NAME;
复制代码
  1. SELECT* FROM OPENQUERY (MYSQLTEST ,'
  2. SELECT
  3.         TABLE_NAME as 表名
  4.          
  5. FROM
  6.         information_schema.TABLES
  7. WHERE
  8.         TABLE_SCHEMA = ''msldbalitest''
  9.         AND TABLE_NAME LIKE ''tp_%''
  10.         AND TABLE_NAME NOT LIKE ''cms_exp%''
  11.     ORDER BY TABLE_NAME desc
  12. ')
复制代码





  1. 2. 查询数据库 ‘ori_data’ 下表 ‘accumulation’ 所有字段注释
  2. SELECT
  3. COLUMN_NAME 字段名,column_comment 字段注释
  4. FROM INFORMATION_SCHEMA.Columns
  5. WHERE table_name='accumulation' AND table_schema='ori_data'
复制代码

  1. select COLUMN_NAME,DATA_TYPE,COLUMN_COMMENT from information_schema.COLUMNS where table_name = '表名' and table_schema = '数据库名称';
复制代码
  1. SELECT* FROM OPENQUERY (MYSQLTEST ,'
  2. SELECT
  3. COLUMN_NAME as 字段名,DATA_TYPE,column_comment as 字段注释
  4. FROM INFORMATION_SCHEMA.Columns
  5. WHERE table_name=''cms_goods'' AND table_schema=''msldbalitest''
  6. ')
复制代码


  1. 3. 查询数据库 "ori_data" 下所有表的表名、表注释以及对应表字段注释
  2. SELECT
  3. a.TABLE_NAME 表名,a.TABLE_COMMENT 表注释,b.COLUMN_NAME 表字段,b.COLUMN_TYPE 字段类型,b.COLUMN_COMMENT 字段注释
  4. FROM information_schema.TABLES a,INFORMATION_SCHEMA.Columns b
  5. WHERE b.TABLE_NAME=a.TABLE_NAME AND a.TABLE_SCHEMA='ori_data'
复制代码
  1. SELECT* FROM OPENQUERY (MYSQLTEST ,'
  2. SELECT
  3. a.TABLE_NAME as 表名,a.TABLE_COMMENT as 表注释,b.COLUMN_NAME as 表字段,b.COLUMN_TYPE as 字段类型,b.COLUMN_COMMENT as 字段注释
  4. FROM information_schema.TABLES a,INFORMATION_SCHEMA.Columns b
  5. WHERE b.TABLE_NAME=a.TABLE_NAME AND a.TABLE_SCHEMA=''msldbalitest''
  6. ')
复制代码
information_schema数据库是MySQL数据库自带的数据库,里面存放的MySQL数据库所有的信息,包罗数据表、数据注释、数据表的索引、数据库的权限等等。



Mysql数据库如何获取某数据库所有表名称(不包含表结构),Sql如下:

  1. SELECT
  2.         table_name
  3. FROM
  4.         information_schema.tables
  5. WHERE table_schema = 'xxx' AND table_type = 'base table'
复制代码
information_schema:Mysql自带的数据库,存放各类数据库相关信息的信息数据库,表多为视图
information_schema.tables:该数据库下的tables表
table_schema:tables表下的一个字段,数据库名称
table_type:tables表下的一个字段,表类型,base table为基础表,注:有空格
table_name:tables表下的一个字段,数据表名称
 

查看指定表的字段及注释


  1. SELECT* FROM OPENQUERY (MYSQLTEST ,'
  2. select
  3.         a.ordinal_position,
  4.         a.COLUMN_name,
  5.         a.COLUMN_type,
  6.         a.COLumn_comment,
  7.         a.is_nullable,
  8.         a.column_key
  9. from
  10.         information_schema.COLUMNS a
  11. where
  12.         TABLE_schema = ''msldbalitest''
  13.         and TABLE_name = ''cms_admin_menu''
  14. ')
复制代码




查看数据所有表名及注释


  1. SELECT* FROM OPENQUERY (MYSQLTEST ,'
  2. select
  3.         t.TABLE_NAME,
  4.         t.TABLE_COMMENT
  5. from
  6.         information_schema.tables t
  7. where
  8.         t.TABLE_TYPE = ''BASE TABLE''
  9.         and TABLE_schema = ''msldbalitest''
  10. ')
复制代码


在mysql中,information_schema这个数据库中生存了mysql服务器所有数据库的信息。
包罗数据库名,数据库的表,表字段的数据类型等。
简而言之,若想知道mysql中有哪些库,哪些表,表里面有哪些字段以及他们的注释,都可以从information_schema中获取
 








COLUMNS表
information_schema库中的COLUMNS表,存放MySQL所有表的字段具体信息。
常用列
TABLE_SCHEMA:数据库名
TABLE_NAME:数据表名
COLUMN_NAME:数据列名
DATA_TYPE:数据类型,如:varchar
COLUMN_TYPE:数据列类型(含数据长度),如:varchar(32)
COLUMN_COMMENT:数据列注释/阐明
 


  1.             string sql = $@"SELECT TABLE_NAME as TableName,
  2.                      column_name AS DbColumnName,
  3.                      CASE WHEN  left(COLUMN_TYPE,LOCATE('(',COLUMN_TYPE)-1)='' THEN COLUMN_TYPE ELSE  left(COLUMN_TYPE,LOCATE('(',COLUMN_TYPE)-1) END AS DataType,
  4.                      CAST(SUBSTRING(COLUMN_TYPE,LOCATE('(',COLUMN_TYPE)+1,LOCATE(')',COLUMN_TYPE)-LOCATE('(',COLUMN_TYPE)-1) AS signed) AS Length,
  5.                      column_default  AS  `DefaultValue`,
  6.                      column_comment  AS  `ColumnComment`,
  7.                      CASE WHEN COLUMN_KEY = 'PRI' THEN true ELSE false END AS `IsPrimaryKey`,
  8.                      CASE WHEN EXTRA='auto_increment' THEN true ELSE false END as IsIdentity,
  9.                      CASE WHEN is_nullable = 'YES' THEN true ELSE false END AS `IsNullable`
  10.                      FROM Information_schema.columns where TABLE_NAME='{tableName}' and  TABLE_SCHEMA=(select database()) ORDER BY TABLE_NAME";
复制代码

利用MySQL创建的表,无论是表注释、索引,照旧字段的类型等等,都会存到MySQL自带的库表中,可以通过SQL查出来想要的表、字段信息。
了解information_schema库,可以在工作中起到意想不到的效果

  1. -- database_name替换为库名,查出库中所有表的TABLE_NAME表名、TABLE_COMMENT表注释
  2. SELECT TABLE_NAME,TABLE_COMMENT FROM information_schema.TABLES WHERE table_schema='database_name';
复制代码

TABLES表

   information_schema库中的TABLES表,存放MySQL所有表的表信息。
  常用列






查询某个表的所有字段
  1. select column_name,data_type,column_comment,column_key,extra,character_maximum_length,is_nullable,column_default
  2. from information_schema.columns
  3. where table_schema = 'seata' and table_name = 'users' ;
复制代码

组装表的所有列
  1. select GROUP_CONCAT("t.",column_name) total
  2. from information_schema.columns
  3. where table_schema = 'seata' and table_name = 'users' and column_name not in ('id');
复制代码














免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4