【数据库】PostgreSQL/PgSql-根据模式名和字段名查询有该字段的所有表信息【通过表元数据信息和函数实现】
一、利用表数据信息查询表和字段信息
(一)从pg_tables中查询表信息
select
tablename
from pg_tables
where
schemaname='ap'
and
tablename SIMILAR TO 'dwd_[a-z,_]+_[0-9]+'
(二)从pg_class和pg_attribute根据指定的表名查询字段信息
SELECT
C.relname,
A.attname AS NAME,
A.attnotnull AS NOTNULL,
format_type ( A.atttypid, A.atttypmod ) AS TYPE,
col_description ( A.attrelid, A.attnum ) AS COMMENT
FROM
pg_class AS C,
pg_attribute AS A
WHERE
C.relname = 'table_name'
AND A.attrelid = C.oid
AND A.attnum > 0
二、函数创建步骤
(一)创建函数
CREATE OR REPLACE FUNCTION ods.find_table_by_column_and_schema()
RETURNS "pg_catalog"."void" AS $BODY$
DECLARE
loop_index integer;
BEGIN
loop_index=1;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
(二)函数调用
select ods.find_table_by_column_and_schema(10);
(三) 输入参数
CREATE OR REPLACE FUNCTION ods.find_table_by_column_and_schema(in_param_schema integer)
RETURNS "pg_catalog"."void" AS $BODY$
DECLARE
loop_index integer;
BEGIN
loop_index=1;
loop_index=loop_index+in_param_schema;
RAISE notice '表名为:%',loop_index;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
(四)删除已创建的函数
DROP FUNCTION find_table_by_column_and_schema(integer)
(五)输出及打印参数
CREATE OR REPLACE FUNCTION ods.find_table_by_column_and_schema(
in_param_schema integer,
OUT out_table_list integer)
RETURNS integer AS $BODY$
DECLARE
loop_index integer;
BEGIN
loop_index=1;
loop_index=loop_index+in_param_schema;
RAISE notice '表名为:%',loop_index;
out_table_list=loop_index;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
(六)测试数组
CREATE OR REPLACE FUNCTION ods.find_table_by_column_and_schema(
in_param_schema integer,
OUT out_table_list character varying[])
RETURNS character varying[] AS $BODY$
DECLARE
loop_index integer;
BEGIN
loop_index=1;
loop_index=loop_index+in_param_schema;
RAISE notice '表名为:%',loop_index;
out_table_list[0]=loop_index;
out_table_list[1]=loop_index+1;
out_table_list[2]=concat(out_table_list[1],cast(1 as character varying));
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
问题:character varying[]和character、varchar的区别
(七)测试与SQL交互
CREATE OR REPLACE FUNCTION ods.find_table_by_column_and_schema(
in_param_schema integer,
OUT out_table_list character varying[])
RETURNS character varying[] AS $BODY$
DECLARE
loop_index integer;
BEGIN
loop_index=1;
loop_index=loop_index+in_param_schema;
RAISE notice '表名为:%',loop_index;
out_table_list[0]=loop_index;
out_table_list[1]=loop_index+1;
out_table_list[2]=(
select count(*) from ap.fact_ito
);
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
三、最终结果
(一)函数内容
CREATE OR REPLACE FUNCTION ods.find_table_by_column_and_schema(
in_param_schema varchar,
in_param_column varchar,
OUT out_table_list character varying[])
RETURNS character varying[]
LANGUAGE 'plpgsql'
COST 100
VOLATILE
AS $BODY$
DECLARE
loop_index integer;
row_record VARCHAR(200);
arr_length integer;
BEGIN
loop_index = 1;
FOR row_record IN(
select
tablename
from pg_tables
where
schemaname=in_param_schema
) LOOP
IF (SELECT count(*)
FROM (SELECT
C.relname,
A.attname AS column_name,
A.attnotnull AS NOTNULL,
format_type ( A.atttypid, A.atttypmod ) AS TYPE,
col_description ( A.attrelid, A.attnum ) AS COMMENT
FROM
pg_class AS C,
pg_attribute AS A
WHERE
C.relname = row_record
AND A.attrelid = C.oid
AND A.attnum > 0
) REF
where column_name=in_param_column)>0
THEN
out_table_list[loop_index]=row_record;
loop_index=loop_index+1;
END IF;
END LOOP;
END;
$BODY$;
(二)调用方式
select ods.find_table_by_column_and_schema('ods','fbillno');
【数据库】PostgreSQL/PgSql-根据模式名和字段名查询有该字段的所有表信息【通过表元数据信息和函数实现】的更多相关文章
- 【转发】在SQL Server中通过字段值查询存储该字段的表
-- Copyright © 2002 Narayana Vyas Kondreddi. All rights reserved. -- Purpose: To search all colu ...
- 查询多表集合(union)、查询时建临时字段、查询时给字段设置默认值
() UNION () UNION (select i.create_time as time,i.investment_amount as amount,i.invest_state as stat ...
- 什么是分析型数据库PostgreSQL版
分析型数据库PostgreSQL版(原HybridDB for PostgreSQL)为您提供简单.快速.经济高效的 PB 级云端数据仓库解决方案.分析型数据库PostgreSQL版 兼容 Green ...
- mysql数据库连接池使用(三)数据库元数据信息反射数据库获取数据库信息
1.1. mysql数据库连接池使用(三)数据库元数据信息反射数据库获取数据库信息 有时候我们想要获取到数据库的基本信息,当前程序连接的那个数据库,数据库的版本信息,数据库中有哪些表,表中都有什么字段 ...
- Mybatis-Plus中使用max、sum聚合函数、只查询指定字段、查询语句多个OR处理
聚合函数查询 可以使用以下方法 QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.select(" I ...
- jdbc链接数据库,获取表名,字段名和数据
import java.sql.Connection; import java.sql.DatabaseMetaData; import java.sql.DriverManager; import ...
- mybatis框架下解决数据库中表的列的字段名和实体类属性不相同的问题
导包.... 实体类中的属性,getter,setter,tostring,构造等方法就不写了 private int id; private String orderNo; private floa ...
- Sqlserver列出所有数据库名,表名,字段名
Sqlserver列出所有数据库名,表名,字段名 1.获取所有数据库名: ? 1 SELECT Name FROM Master..SysDatabases ORDER BY Name 注 ...
- [SQL]获取所有数据库名、获取数据库中表名、获取表中的字段名
--()获取所有数据库名: Select Name FROM Master..SysDatabases order by Name --()获取所有表名 --XType=''U'':表示所有用户表; ...
- 获取sqlserver数据库中所有库、表、字段名的方法
获取sqlserver数据库中所有库.表.字段名的方法 2009年03月12日 星期四 下午 12:51 1.获取所有数据库名: SELECT Name FROM Master..SysDatabas ...
随机推荐
- kratos v2版本命令行工具使用
使用 下载 go install github.com/go-kratos/kratos/cmd/kratos/v2@latest 查看是否安装成功 kratos -v kratos version ...
- SpringSecurity基本使用
SpringSecurity web 安全管理框架 需要依赖多 shiro 轻量 SSM+Shiro SpringBoot/SpringCloud+SpringSecurity 配置用户名密码 配置文 ...
- 连接Vue.js作为前端,Fastapi作为后端
项目结构 ├── main.py └── templates └── home.html 环境安装 pip install fastapi[all] pip install jinja2 Backen ...
- docker方式安装Redash
之前使用的项目GitHub地址是https://github.com/dazdata/redash.git,这个是直接复制国外的项目的,地址:https://github.com/getredash/ ...
- RabbitMQ原理和架构图解(附6大工作模式)
为什么要使用RabbitMQ? 1.解耦 系统A在代码中直接调用系统B和系统C的代码,如果将来D系统接入,系统A还需要修改代码,过于麻烦. 2.异步 将消息写入消息队列,非必要的业务逻辑以异步的方式运 ...
- AVX图像算法优化系列二: 使用AVX2指令集加速查表算法。
查表算法,无疑也是一种非常常用.有效而且快捷的算法,我们在很多算法的加速过程中都能看到他的影子,在图像处理中,尤其常用,比如我们常见的各种基于直方图的增强,可以说,在photoshop中的调整菜单里8 ...
- asp.net core web 解决方案多项目模板制作打包总结
一.文件夹\项目结构 1.1.文件夹 net6.0:针对.net 6.0 项目模板 net6.0pack:针对net6.0打包 1.2.项目结构 Web\WebApi多项目.各层项目.单元测试项目 目 ...
- ULID规范解读与实现原理
前提 最近发现各个频道推荐了很多ULID相关文章,这里对ULID的规范文件进行解读,并且基于Java语言自行实现ULID,通过此实现过程展示ULID的底层原理. ULID出现的背景 ULID全称是Un ...
- 在IDEA 、springboot中使用切面aop实现日志信息的记录到数据库
文章目录 1.导入相关的依赖 2.创建要保存的数据信息实体类 3 .编写对应的sql语句 4.使用spring 的 aop 技术切到自定义注解上,所以先创建一个自定义注解类 5. 创建aop切面实现类 ...
- iOS开发之自定义日历控件
前言 日常开发中经常会遇到日期选择,为了方便使用,简单封装了一个日历控件,在此抛砖引玉供大家参考. 效果 功能 支持单选.区间 支持默认选中日期 支持限制月份 支持过去.当前.未来模式 支持frame ...