饿虎岗资源网 Design By www.oxmxm.com
今天更新两个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)
示例:
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
饿虎岗资源网 Design By www.oxmxm.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
饿虎岗资源网 Design By www.oxmxm.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年09月21日
2024年09月21日
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- 任天堂今晚举行直面会!第三方及独立游戏展示
- 《哆啦A梦的铜锣烧店物语》发售!开罗公式+哆啦A梦
- 任天堂公布《塞尔达传说》系列时间线:野炊与王泪独立在外
- 五条人.2012-一些风景2CD【刀马旦】【WAV+CUE】
- 陈奕迅.2013-Easons.Life演唱会2CD(2024环球红馆40复刻系列)【环球】【WAV+CUE】
- 许美静.1995-遗憾(新马版)【上华】【WAV+CUE】
- 《叶倩文 歌声情缘》[WAV+CUE][410MB]
- 《张国荣 首首动听经典不容错过 追忆的风 2CD》[WAV+CUE][870MB]
- 《腾格尔 容中尔甲 亚东 高原三星 男人篇 3CD》[WAV/分轨][1GB]
- 命运圣契公测实测可用兑换码大全 命运圣契最新兑换码分享
- 黑神话悟空上品疾蝠精魄获取方法一览|上品疾蝠精魄收集攻略
- 《七龙珠电光炸裂!ZERO》GT角色预告片曝光,15位新角色登场
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- NewViennaOctetViennaWindSoloists-TheDeccaRecordings(2024)18CD[24-48][FLAC]-7