获取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

相关文章

python获取网页表格的多种方法汇总

《python获取网页表格的多种方法汇总》我们在网页上看到很多的表格,如果要获取里面的数据或者转化成其他格式,就需要将表格获取下来并进行整理,在Python中,获取网页表格的方法有多种,下面就跟随小编... 目录1. 使用Pandas的read_html2. 使用BeautifulSoup和pandas3.

SpringBoot UserAgentUtils获取用户浏览器的用法

《SpringBootUserAgentUtils获取用户浏览器的用法》UserAgentUtils是于处理用户代理(User-Agent)字符串的工具类,一般用于解析和处理浏览器、操作系统以及设备... 目录介绍效果图依赖封装客户端工具封装IP工具实体类获取设备信息入库介绍UserAgentUtils

C# foreach 循环中获取索引的实现方式

《C#foreach循环中获取索引的实现方式》:本文主要介绍C#foreach循环中获取索引的实现方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、手动维护索引变量二、LINQ Select + 元组解构三、扩展方法封装索引四、使用 for 循环替代

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法

《golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法》:本文主要介绍golang获取当前时间、时间戳和时间字符串及它们之间的相互转换,本文通过实例代码给大家介绍的非常详细,感兴趣... 目录1、获取当前时间2、获取当前时间戳3、获取当前时间的字符串格式4、它们之间的相互转化上篇文章给大家介

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,