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

相关文章

MySQL 获取字符串长度及注意事项

《MySQL获取字符串长度及注意事项》本文通过实例代码给大家介绍MySQL获取字符串长度及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 获取字符串长度详解 核心长度函数对比⚠️ 六大关键注意事项1. 字符编码决定字节长度2

python3如何找到字典的下标index、获取list中指定元素的位置索引

《python3如何找到字典的下标index、获取list中指定元素的位置索引》:本文主要介绍python3如何找到字典的下标index、获取list中指定元素的位置索引问题,具有很好的参考价值,... 目录enumerate()找到字典的下标 index获取list中指定元素的位置索引总结enumerat

SpringMVC高效获取JavaBean对象指南

《SpringMVC高效获取JavaBean对象指南》SpringMVC通过数据绑定自动将请求参数映射到JavaBean,支持表单、URL及JSON数据,需用@ModelAttribute、@Requ... 目录Spring MVC 获取 JavaBean 对象指南核心机制:数据绑定实现步骤1. 定义 Ja

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

Python pip下载包及所有依赖到指定文件夹的步骤说明

《Pythonpip下载包及所有依赖到指定文件夹的步骤说明》为了方便开发和部署,我们常常需要将Python项目所依赖的第三方包导出到本地文件夹中,:本文主要介绍Pythonpip下载包及所有依... 目录步骤说明命令格式示例参数说明离线安装方法注意事项总结要使用pip下载包及其所有依赖到指定文件夹,请按照以

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

使用Python实现获取屏幕像素颜色值

《使用Python实现获取屏幕像素颜色值》这篇文章主要为大家详细介绍了如何使用Python实现获取屏幕像素颜色值,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、一个小工具,按住F10键,颜色值会跟着显示。完整代码import tkinter as tkimport pyau

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1