在这里,我们将给大家分享关于Postgresql查询表引用或被引用的外键操作的知识,同时也会涉及到如何更有效地centos7下源码编译安装php支持PostgreSQLpostgresql手册post
在这里,我们将给大家分享关于Postgresql 查询表引用或被引用的外键操作的知识,同时也会涉及到如何更有效地centos 7下源码编译安装php支持PostgreSQL postgresql手册 postgresql官网下载 postgresql视频教、ORACLE 查询当前表被其他表引用的外键、Postgres 函数在 RETURN QUERY 中传递表引用和字符串、PostgreSQL - 查询表结构和索引信息的内容。
本文目录一览:- Postgresql 查询表引用或被引用的外键操作
- centos 7下源码编译安装php支持PostgreSQL postgresql手册 postgresql官网下载 postgresql视频教
- ORACLE 查询当前表被其他表引用的外键
- Postgres 函数在 RETURN QUERY 中传递表引用和字符串
- PostgreSQL - 查询表结构和索引信息
Postgresql 查询表引用或被引用的外键操作
项目招商找A5 快速获取精准代理名单
这篇文章主要介绍了Postgresql 查询表引用或被引用的外键操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
今天更新两个SQL。是用来查询PG中,主表被子表引用的外键,或子表引用了哪个主表的主键。
废话不多说,直接上实验!
CentOS 7 + PG 10
创建两个实验表,test01为主表,test02为子表,test02引用test01中的id列。
test=# create table test01(
test(# id int primary key,
test(# col1 varchar(20)
test(# );
CREATE TABLE
test=# create table test02(
test(# id int primary key,
test(# test01_id int references test01(id),
test(# col1 varchar(20)
test(# );
CREATE TABLE
插入数据
test=# insert into test01 values (1, 'a');
INSERT 0 1
test=# insert into test01 values (2, 'b');
INSERT 0 1
test=# insert into test01 values (3, 'c');
INSERT 0 1
test=# insert into test02 values (1, 1, 'a');
INSERT 0 1
test=# insert into test02 values (2, 1, 'a');
INSERT 0 1
test=# insert into test02 values (3, 1, 'a');
INSERT 0 1
test=# insert into test02 values (4, 2, 'b');
INSERT 0 1
test=# insert into test02 values (5, 2, 'b');
INSERT 0 1
test=# insert into test02 values (6, 11, 'b');
ERROR: insert or update on table "test02" violates foreign key constraint "test02_test01_id_fkey"
DETAIL: Key (test01_id)=(11) is not present in table "test01".
查询主表被哪个子表引用。如果结果为空,说明没有任何子表引用的该表。
test=# SELECT
tc.constraint_name,
tc.table_name, # 子表
kcu.column_name,
ccu.table_name AS foreign_table_name, # 主表
ccu.column_name AS foreign_column_name,
tc.is_deferrable,
tc.initially_deferred
FROM
information_schema.table_constraints AS tc
JOIN information_schema.key_column_usage AS kcu ON tc.constraint_name = kcu.constraint_name
JOIN information_schema.constraint_column_usage AS ccu ON ccu.constraint_name = tc.constraint_name
where constraint_type = 'FOREIGN KEY' AND ccu.table_name='test01'; # 输入主表
constraint_name | table_name | column_name | foreign_table_name | foreign_column_name | is_deferrable | initially_deferred
-----------------------+------------+-------------+--------------------+---------------------+---------------+--------------------
test02_test01_id_fkey | test02 | test01_id | test01 | id | NO | NO
(1 row)
查询子表引用的哪个主表。如果结果为空,说明没有任何引用主表。
test=# SELECT
tc.constraint_name,
tc.table_name, # 子表
kcu.column_name,
ccu.table_name AS foreign_table_name,
ccu.column_name AS foreign_column_name, # 主表
tc.is_deferrable,
tc.initially_deferred
FROM
information_schema.table_constraints AS tc
JOIN information_schema.key_column_usage AS kcu ON tc.constraint_name = kcu.constraint_name
JOIN information_schema.constraint_column_usage AS ccu ON ccu.constraint_name = tc.constraint_name
WHERE constraint_type = 'FOREIGN KEY' AND tc.table_name='test02'; # 输入子表
constraint_name | table_name | column_name | foreign_table_name | foreign_column_name | is_deferrable | initially_deferred
-----------------------+------------+-------------+--------------------+---------------------+---------------+--------------------
test02_test01_id_fkey | test02 | test01_id | test01 | id | NO | NO
(1 row)
补充:PostgreSQL 外键引用查询
根据一个表名,查询所有外键引用它的表,以及那些外键的列名
key_column_usage(系统列信息表),
pg_constraint(系统所有约束表)
SELECT x.table_name,
x.column_name
FROM information_schema.key_column_usage x
INNER JOIN (SELECT t.relname,
a.conname
FROM pg_constraint a
INNER JOIN pg_class ft
ON ft.oid = a.confrelid
INNER JOIN pg_class t
ON t.oid = a.conrelid
WHERE a.contype = 'f'
AND a.confrelid =
(select e.oid
from pg_class e
where e.relname = 'xxx_table')
) tp
ON (x.table_name = tp.relname AND
x.constraint_name = tp.conname)
示例:

文章来源:
来源地址:https://www.jb51.net/article/205219.htm

centos 7下源码编译安装php支持PostgreSQL postgresql手册 postgresql官网下载 postgresql视频教
1. 下载源码
$ mkdir /usr/downloads $ wget -c http://cn2.php.net/distributions/php-5.6.20.tar.gz $ tar -xvf php-5.6.20.tar.gz $ mv php-5.6.20 /usr/local/src $ cd !$ & cd php-5.6.20
2. 阅读安装指导
$ ls -also $ less README $ less INSTALL
3. 安装依赖包
$ yum install apr apr-util apr-devel apr-util-devel prce lynx
4. 安装httpd
$ wget -c http://apache.fayea.com//httpd/httpd-2.4.20.tar.gz $ tar -xvf httpd-2.4.20.tar.gz $ cd httpd-2.4.20 $ ./configure \ --prefix=/usr/local/programs/apache2 \ --enable-rewrite \ --enable-so \ --enable-headers \ --enable-expires \ --with-mpm=worker \ --enable-modules=most \ --enable-deflate \ --enable-module=shared $ make $ make install $ cd /usr/local/programs/apache2 $ cp bin/apachectl /etc/init.d/httpd ## 复制启动脚本 $ /etc/init.d/httpd start ## 启动apache服务器,访问http://localhost/ $ egrep -v ''^[ ]*#|^$'' /usr/local/apache2/conf/httpd.conf | nl ## 查看apache服务器的配置 ## 将apache加入系统服务 vi /etc/rc.d/rc.local ``` /usr/local/programs/apache2/bin/apachectl start ``` $ cat /etc/rc.local
4. 安装postgresql
立即学习“PHP免费学习笔记(深入)”;
$ yum install readline-devel ## 安装readline依赖 $ cd /usr/downloads $ wget -c https://ftp.postgresql.org/pub/source/v9.5.0/postgresql-9.5.0.tar.bz2 $ tar -xvf postgresql-9.5.0.tar.bz2 $ cd postgresql-9.5.0 $ ./configure --prefix=/usr/local/programs/postgresql $ make $ su $ make install $ /sbin/ldconfig /usr/local/programs/postgresql/lib ## 刷新下共享动态库 $ cd /usr/local/programs/postgresql $ bin/psql --version ## 检查运行情况 ## 开始对postgresql的配置 $ vi /etc/profile.d/postgresql.sh ## 增加环境变量,不推荐直接在/etc/profile中添加,系统更新升级时会需要merge ``` PATH=/usr/local/programs/postgresql:$PATH export PATH ``` $ source /etc/profile ## 更新环境变量 ## 增加用户和其他文件夹 $ adduser postgres $ passwd postgres $ mkdir /usr/local/programs/postgresql/logs $ mkdir /usr/local/programs/postgresql/data $ chown postgres /usr/local/programs/postgresql/data $ su - postgres ## 初始化数据库 $ ./bin/initdb -D ./data $ ./bin/createdb test $ ./bin/psql test ## 已有数据库,可导入data文件夹后尝试root访问,假如带密码,可能需要进一步研究下 $ ./bin/postgres -D ./data >./logs/start-log-1.log 2>&1 & $ ./bin/psql --list ##列出数据库 ## ok,安装完成 ## 自定义设置,权限控制等,可以跳过,等熟悉使用后再做 ## 编辑数据库配置及权限文件: $ vi /usr/local/programs/postgresql/data/postgresql.conf ## 数据库配置文件 $ chown postgres postgresql.conf $ chmod 644 postgresql.conf $ vi /usr/local/programs/postgresql/data/pg_hba.conf ## 权限文件 $ vi /usr/local/programs/postgresql/data/pg_ident.conf ## 设置开机自启动: $ vi /etc/rc.d/rc.local ## 添加如下内容 ``` /usr/local/programs/postgresql/bin/postgresql start ```
5. 安装php
## 源码已经在第一步中下载,现在开始安装: $ yum install libxml2 libxml2-devel libpng libpng-devel libjpeg libjpeg-devel freetype freetype-devel $ ./configure \ --prefix=/usr/local/programs/php \ --with-apxs2=/usr/local/programs/apache2/bin/apxs \ --with-zlib \ --with-gd \ --with-jpeg-dir \ --with-png-dir \ --with-freetype-dir \ --with-zlib-dir \ --enable-mbstring \ --with-pgsql=/usr/local/programs/postgresql \ --with-pdo-pgsql=/usr/local/programs/postgresql $ make $ make test > Bug #42718 (unsafe_raw filter not applied when configured as default filter) [ext/filter/tests/bug42718.phpt] XFAIL REASON: FILTER_UNSAFE_RAW not applied when configured as default filter, even with flags > Bug #67296 (filter_input doesn''t validate variables) [ext/filter/tests/bug49184.phpt] XFAIL REASON: See Bug #49184 > Bug #53640 (XBM images require width to be multiple of 8) [ext/gd/tests/bug53640.phpt] XFAIL REASON: Padding is not implemented yet > zend multibyte (7) [ext/mbstring/tests/zend_multibyte-07.phpt] XFAIL REASON: https://bugs.php.net/bug.php?id=66582 > zend multibyte (9) [ext/mbstring/tests/zend_multibyte-09.phpt] XFAIL REASON: https://bugs.php.net/bug.php?id=66582 >Bug #70470 (Built-in server truncates headers spanning over TCP packets) [sapi/cli/tests/bug70470.phpt] XFAIL REASON: bug is not fixed yet ## 查阅官方的bug,发现: > id=66582: status : Closed. Fixed in master (PHP7) > id=42718: status : Assigned > id=42718: reference to id=49184, unsolved for many years ## 那就不关心了,直接装吧 $ make install > You may want to add: /usr/local/programs/php/lib/php to your php.ini include_path ## 那就按它说的设置吧 $ cp php.ini-development /usr/local/programs/php/lib/php.ini ``` include_path = ".;/usr/local/programs/php/lib/php" ## 然后,编辑httpd的设置,确保其能正确解析php文件 ``` ... LoadModule php5_module modules/libphp5.so ... AddType application/x-httpd-php .php AddType application/x-httpd-php-source .php5 ... <ifmodule dir_module> DirectoryIndex index.html index.php </ifmodule> ``` ## 重启httpd,测试 $ cd /usr/local/programs/apache2 $ bin/httpd -h $ bin/httpd -k stop $ bin/httpd -f conf/httpd.conf ## 默认设置的www页面在./htdocs/下,那就先去里面建一个测试页面吧 $ vi htdocs/index.php ``` <?php phpinfo(); ?> ``` $ curl http://localhost/index.php |grep postgresql #ok
后续应该做的事
* 1. 启动时,不需要要手动指定配置文件
* 2. php初始化www目录设置
* 3. php 用户、权限管理等
以上就介绍了centos 7下源码编译安装php支持PostgreSQL,包括了postgresql,centos 7方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
ORACLE 查询当前表被其他表引用的外键
用到两个表
USER_CONSTRAINTS 系统表:主键外键信息表,P 代表主键,R 代表外键
USER_CONS_COLUMNS 系统表:字段信息表,
select T_CUR_CONS.TABLE_NAME CUR_TABLE_NAME, --当前表名
T_CUR_COLUMNS.COLUMN_NAME CUR_COLUMN_NAME, --当前字段名
T_CONS.R_CONSTRAINT_NAME CUR_COLUMN_ID, --当前字段ID
T_CONS.TABLE_NAME REF_TABLE_NAME, --引用表名称
T_CONS.CONSTRAINT_NAME REF_COLUMN_ID, --引用表外键字段名
T_REF_COLUMNS.COLUMN_NAME REF_COLUMN_NAME --引用表外键字段ID
from USER_CONSTRAINTS T_CONS --所有的主键外键数据
LEFT JOIN USER_CONSTRAINTS T_CUR_CONS --当前主键表
ON T_CONS.R_CONSTRAINT_NAME = T_CUR_CONS.CONSTRAINT_NAME
LEFT JOIN USER_CONS_COLUMNS T_CUR_COLUMNS --当前字段表
ON T_CONS.R_CONSTRAINT_NAME = T_CUR_COLUMNS.CONSTRAINT_NAME
LEFT JOIN USER_CONS_COLUMNS T_REF_COLUMNS --引用字段表
ON T_CONS.CONSTRAINT_NAME = T_REF_COLUMNS.CONSTRAINT_NAME
WHERE T_CONS.CONSTRAINT_TYPE = ''R'' --当前主键类型为R:主键
AND T_CUR_CONS.TABLE_NAME = ''T_OAUTH_USER'' --查询表名
AND T_CUR_CONS.CONSTRAINT_TYPE = ''P''; --查询字段的主键类型P:外键,在其他表就是外键
----------------------------以下是分步骤查询------------------------------------------
--查询当前表主键信息,主要查询主键ID:CONSTRAINT_NAME
SELECT * FROM USER_CONSTRAINTS WHERE CONSTRAINT_TYPE = ''P'' AND TABLE_NAME = ''T_OAUTH_USER'';
--查询当前表表名和字段信息(这一步骤可以去掉,加上只为了完善描述而已)
SELECT * FROM USER_CONS_COLUMNS WHERE CONSTRAINT_NAME = ''SYS_C0012872'';
--查询当前表被引用记录(在其他表作为外键的记录),主要查询外键ID:CONSTRAINT_NAME
SELECT * FROM USER_CONSTRAINTS WHERE R_CONSTRAINT_NAME = ''SYS_C0012872'';
--查询当前表主键作为其他表的外键记录
-- 比如上一步骤查询出三条记录( SYS_C0012908 SYS_C0012907 SYS_C0013232)
SELECT * FROM USER_CONS_COLUMNS WHERE CONSTRAINT_NAME in (''SYS_C0012908'',''SYS_C0012907'',''SYS_C0013232'');
Postgres 函数在 RETURN QUERY 中传递表引用和字符串
%I
是用于创建查询的 schema.tablename
部分的标识符。查询的这一部分 WHERE i.webid = %I
正在寻找数据值而不是标识符。您需要使用 %L
。此外,正如@Chris 指出的那样,您对该值使用了错误的变量。
PostgreSQL - 查询表结构和索引信息
前言
Postgresql的表一般都是建立在public这个schema下的,假如现在有个数据表t_student
,可以用以下几种方式来查询表结构和索引信息。
使用\d元命令查看表字段信息和索引信息
在cmd界面使用psql连接db后,输入\d加上表名即可:
\d t_student
通过系统数据字典查询表结构
select col.table_schema,col.table_name,col.ordinal_position,col.column_name,col.data_type,col.character_maximum_length,col.numeric_precision,col.numeric_scale,col.is_nullable,col.column_default,des.description from information_schema.columns col left join pg_description des on col.table_name::regclass = des.objoid and col.ordinal_position = des.objsubid where table_schema = ‘public‘ and table_name = ‘t_student‘ order by ordinal_position;
或者简单点:
select * from information_schema.columns where table_schema=‘public‘ and table_name=‘t_student‘;
通过系统数据字典查询索引信息
select A.SCHEMANAME,A.TABLENAME,A.INDEXNAME,A.TABLESPACE,A.INDEXDEF,B.AMNAME,C.INDEXRELID,C.INDNATTS,C.INdisUNIQUE,C.INdisPRIMARY,C.INdisCLUSTERED,D.DESCRIPTION from PG_AM B left join PG_CLASS F on B.OID = F.RELAM left join PG_STAT_ALL_INDEXES E on F.OID = E.INDEXRELID left join PG_INDEX C on E.INDEXRELID = C.INDEXRELID left outer join PG_DESCRIPTION D on C.INDEXRELID = D.OBJOID,PG_INDEXES A where A.SCHEMANAME = E.SCHEMANAME and A.TABLENAME = E.RELNAME and A.INDEXNAME = E.INDEXRELNAME and E.SCHEMANAME = ‘public‘ and E.RELNAME = ‘t_student‘;
查询所有的表名
select n.nspname,relname from pg_class c,pg_namespace n where c.relnamespace = n.oid and nspname = ‘public‘ and relkind = ‘r‘ order by relname;
可视化工具DBeaver
对于上述的sql语句只需要修改要查询的table name,可以根据需要自行修改想要查询的column。如果是通过DBeaver来连接数据库,还可以直接在当前的数据库实例下打开schema里的public选项,接着选中table,选中你想查看的表,可以很直观地看到该表的各种信息:column、index等等。
参考链接
- PostgreSQL:如何查询表的字段信息?
我们今天的关于Postgresql 查询表引用或被引用的外键操作的分享已经告一段落,感谢您的关注,如果您想了解更多关于centos 7下源码编译安装php支持PostgreSQL postgresql手册 postgresql官网下载 postgresql视频教、ORACLE 查询当前表被其他表引用的外键、Postgres 函数在 RETURN QUERY 中传递表引用和字符串、PostgreSQL - 查询表结构和索引信息的相关信息,请在本站查询。
本文标签: