获取schema所有表获取某表所有字段

2024-06-20 09:58
文章标签 所有 获取 schema 某表

本文主要是介绍获取schema所有表获取某表所有字段,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

注:以下为postgresql,其他数据库的略过哈

\d[+] table_name 查看【详细】表结构

要获取某个schame下的所有表,或者获取某个表的所有字段,需要依赖这两个表:
information_schema.tables 与 information_schema.columns

第一个表存放的是所有schema下所有表的信息

\d information_schema.tables View "information_schema.tables"Column            |               Type                | Modifiers 
------------------------------+-----------------------------------+-----------table_catalog                | information_schema.sql_identifier | table_schema                 | information_schema.sql_identifier | table_name                   | information_schema.sql_identifier | table_type                   | information_schema.character_data | self_referencing_column_name | information_schema.sql_identifier | reference_generation         | information_schema.character_data | user_defined_type_catalog    | information_schema.sql_identifier | user_defined_type_schema     | information_schema.sql_identifier | user_defined_type_name       | information_schema.sql_identifier | is_insertable_into           | information_schema.yes_or_no      | is_typed                     | information_schema.yes_or_no      | commit_action                | information_schema.character_data | 

第二个表是存放所有schema下所有表的字段名称

\d information_schema.columnsView "information_schema.columns"Column          |                Type                | Modifiers 
--------------------------+------------------------------------+-----------table_catalog            | information_schema.sql_identifier  | table_schema             | information_schema.sql_identifier  | table_name               | information_schema.sql_identifier  | column_name              | information_schema.sql_identifier  | ordinal_position         | information_schema.cardinal_number | column_default           | information_schema.character_data  | is_nullable              | information_schema.yes_or_no       | data_type                | information_schema.character_data  | character_maximum_length | information_schema.cardinal_number | character_octet_length   | information_schema.cardinal_number | numeric_precision        | information_schema.cardinal_number | numeric_precision_radix  | information_schema.cardinal_number | numeric_scale            | information_schema.cardinal_number | datetime_precision       | information_schema.cardinal_number | interval_type            | information_schema.character_data  | interval_precision       | information_schema.cardinal_number | character_set_catalog    | information_schema.sql_identifier  | character_set_schema     | information_schema.sql_identifier  | character_set_name       | information_schema.sql_identifier  | collation_catalog        | information_schema.sql_identifier  | collation_schema         | information_schema.sql_identifier  | collation_name           | information_schema.sql_identifier  | domain_catalog           | information_schema.sql_identifier  | domain_schema            | information_schema.sql_identifier  | domain_name              | information_schema.sql_identifier  | udt_catalog              | information_schema.sql_identifier  | udt_schema               | information_schema.sql_identifier  | udt_name                 | information_schema.sql_identifier  | scope_catalog            | information_schema.sql_identifier  | scope_schema             | information_schema.sql_identifier  | scope_name               | information_schema.sql_identifier  | maximum_cardinality      | information_schema.cardinal_number | dtd_identifier           | information_schema.sql_identifier  | is_self_referencing      | information_schema.yes_or_no       | is_identity              | information_schema.yes_or_no       | identity_generation      | information_schema.character_data  | identity_start           | information_schema.character_data  | identity_increment       | information_schema.character_data  | identity_maximum         | information_schema.character_data  | identity_minimum         | information_schema.character_data  | identity_cycle           | information_schema.yes_or_no       | is_generated             | information_schema.character_data  | generation_expression    | information_schema.character_data  | is_updatable             | information_schema.yes_or_no       | 

跟据这两张表的字段,要获取某个schema的所有表及获取某表的所有字段就会变得很容易。

获取某个schame下的所有表:

select table_name from information_schema.tables where table_schema='schema_name' and table_type='table_name';

获取某表所有字段

select column_name from information_schema.columns where table_schema='schema_name' and table_name='table_name'

获取某表存放文本的字段

select column_name,data_type from information_schema.columns where table_schema='table_schema' and table_name='table_name' and data_type in ('character varying', 'text');

这篇关于获取schema所有表获取某表所有字段的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1077812

相关文章

如何利用Java获取当天的开始和结束时间

《如何利用Java获取当天的开始和结束时间》:本文主要介绍如何使用Java8的LocalDate和LocalDateTime类获取指定日期的开始和结束时间,展示了如何通过这些类进行日期和时间的处... 目录前言1. Java日期时间API概述2. 获取当天的开始和结束时间代码解析运行结果3. 总结前言在J

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

java获取图片的大小、宽度、高度方式

《java获取图片的大小、宽度、高度方式》文章介绍了如何将File对象转换为MultipartFile对象的过程,并分享了个人经验,希望能为读者提供参考... 目China编程录Java获取图片的大小、宽度、高度File对象(该对象里面是图片)MultipartFile对象(该对象里面是图片)总结java获取图片

Java通过反射获取方法参数名的方式小结

《Java通过反射获取方法参数名的方式小结》这篇文章主要为大家详细介绍了Java如何通过反射获取方法参数名的方式,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、解决方式方式2.1: 添加编译参数配置 -parameters方式2.2: 使用Spring的内部工具类 -

Java如何获取视频文件的视频时长

《Java如何获取视频文件的视频时长》文章介绍了如何使用Java获取视频文件的视频时长,包括导入maven依赖和代码案例,同时,也讨论了在运行过程中遇到的SLF4J加载问题,并给出了解决方案... 目录Java获取视频文件的视频时长1、导入maven依赖2、代码案例3、SLF4J: Failed to lo

使用Java实现获取客户端IP地址

《使用Java实现获取客户端IP地址》这篇文章主要为大家详细介绍了如何使用Java实现获取客户端IP地址,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 首先是获取 IP,直接上代码import org.springframework.web.context.request.Requ

C++实现获取本机MAC地址与IP地址

《C++实现获取本机MAC地址与IP地址》这篇文章主要为大家详细介绍了C++实现获取本机MAC地址与IP地址的两种方式,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实际工作中,项目上常常需要获取本机的IP地址和MAC地址,在此使用两种方案获取1.MFC中获取IP和MAC地址获取

C/C++通过IP获取局域网网卡MAC地址

《C/C++通过IP获取局域网网卡MAC地址》这篇文章主要为大家详细介绍了C++如何通过Win32API函数SendARP从IP地址获取局域网内网卡的MAC地址,感兴趣的小伙伴可以跟随小编一起学习一下... C/C++通过IP获取局域网网卡MAC地址通过win32 SendARP获取MAC地址代码#i

5分钟获取deepseek api并搭建简易问答应用

《5分钟获取deepseekapi并搭建简易问答应用》本文主要介绍了5分钟获取deepseekapi并搭建简易问答应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1、获取api2、获取base_url和chat_model3、配置模型参数方法一:终端中临时将加

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.