首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何在PostgreSQL9.5中检索特定模式的所有键及其列名和表名?

在PostgreSQL9.5中,可以使用以下查询来检索特定模式的所有键及其列名和表名:

代码语言:txt
复制
SELECT
    conname AS constraint_name,
    conrelid::regclass AS table_name,
    a.attname AS column_name
FROM
    pg_constraint c
JOIN
    pg_attribute a ON a.attnum = ANY(c.conkey) AND a.attrelid = c.conrelid
JOIN
    pg_namespace n ON n.oid = c.connamespace
WHERE
    n.nspname = 'your_schema_name'
    AND c.contype = 'f'
ORDER BY
    conname;

上述查询中,将your_schema_name替换为你要检索的特定模式的名称。

这个查询使用了以下系统表:

  • pg_constraint:包含了所有约束的信息。
  • pg_attribute:包含了表的列信息。
  • pg_namespace:包含了所有命名空间(模式)的信息。

查询结果将包含以下信息:

  • constraint_name:外键约束的名称。
  • table_name:包含外键的表名。
  • column_name:外键列的名称。

这样,你就可以通过这个查询来检索特定模式的所有键及其列名和表名了。

腾讯云相关产品和产品介绍链接地址:

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

【数据库设计和SQL基础语法】--SQL语言概述--SQL的基本结构和语法规则(一)

标识符(Identifiers): 定义:用于标识数据库中的对象名称,如表名、列名。 规则:字母开头,可包含字母、数字、下划线等字符。 例子:表名、列名等。...调试和排错:在代码中添加注释有助于在调试和排错过程中理解特定部分的作用。 文档化:注释可以用于生成代码文档,帮助开发者了解数据库结构和查询逻辑。...Tip:在实际应用中,创建表时可能还涉及其他约束(如外键、唯一约束等)以及其他可选项,具体取决于数据库管理系统的支持和设计需求。...FROM table_name; 其中,column1, column2, ...是要检索的列名,而table_name是要检索数据的表名。...约束如主键、唯一约束、外键、检查约束、默认约束和非空约束用于确保数据完整性和一致性。数据操作语言(DML)包括插入、查询、更新和删除数据。

1.1K10

【MySQL学习】基础指令全解:构建你的数据库技能

注:若确实想让表名/列名 和关键字一样,可以使用 反引号 ` (键盘左上角,ESC下面,tab上面的那个按键)来吧表名 列名引起来,此处列名 在前面,类型 在后面。...,我们统一将外部关键字叫做外键,外键就是另一张表中的主键。...; // 把表中所有行所有列都查询出来 注:其中上面的 * 是通配符,可以代指所有列 指定列查询 select 列名, 列名... from 表名; 查询字段为表达式 (一边查询,一边计算) 在查询的时候...,写作由列名构成的表达式,把这一列的所有行都带入到表达式中 注:但是原始数据不变,这个只是产生的临时数据。...全文索引(FULLTEXT): 全文索引用于加速对文本字段的全文检索,如查找包含特定单词的记录。它适用于大量文本数据的搜索。

15310
  • SQL命令 INSERT(一)

    这与启用PTools时生成的代码相同。不同之处在于,SQLStats收集代码只为该特定语句生成。正在编译的例程/类中的所有其他SQL语句将生成代码,就像PTools已关闭一样。...%PROFILE_ALL收集主查询模块及其所有子查询模块的SQLStat。 可以按任意顺序指定多个%KEYWORD参数。多个参数由空格分隔。...表参数 可以指定要直接插入到表中的表参数、通过视图插入的表参数或通过子查询插入的表参数。如创建视图中所述,通过视图插入受要求和限制的约束。...例如,日期存储为天数的整数,时间存储为午夜起的秒数,%list存储为编码字符串。大多数其他数据(如字符串和数字)不需要转换;无论当前模式如何,它们都以相同的格式输入和存储。...特殊变量 可以在列中插入以下特殊变量的值: %TABLENAME或%CLASSNAME伪字段变量关键字。%TABLENAME返回当前表名。%CLASSNAME返回与当前表对应的类名。

    6K20

    SqlAlchemy 2.0 中文文档(三十九)

    作为最佳实践,请确保数据库的“默认”模式只是一个单一名称,而不是名称列表;对于属于此“默认”模式并且可以在 DDL 和 SQL 中不带模式限定命名的表,请将相应的Table.schema和类似的模式参数设置为它们的默认值...一些数据库,如 PostgreSQL,将这个概念进一步扩展为 模式搜索路径,在特定数据库会话中可以考虑多个模式名称为“隐式”;引用其中任何一个模式中的表名都不需要存在模式名称(与此同时,如果模式名称存在...有关更多信息,请参阅正在使用的方言的文档。 返回: 一个字典,其键为二元组模式、表名,值为表示表注释的字典。如果未提供模式,则模式为 None。 2.0 版中的新内容。...可以使用Table.schema参数为Table对象以及其他对象如视图、索引和序列设置“模式”,还可以使用MetaData.schema参数为MetaData对象设置默认模式。...一些数据库,如 PostgreSQL,将这个概念进一步发展成为模式搜索路径的概念,其中一个特定数据库会话中可以考虑多个模式名称为“隐式”;引用任何这些模式中的表名都不需要模式名(同时如果模式名存在也完全可以

    42610

    mysql 必知必会整理—sql 简单语句

    SHOW COLUMNS 要求给出一个表名(这个例子中的 FROM customers),它对每个字段返回一行,行中包含字段名、数据类型、是否允许NULL、键信息、默认值以及其他信息(如字段cust_id...许多SQL开发人员喜欢对所有SQL关键字使用大写,而对所有列和表名使用小写,这样做使代码更易于阅读和调试。 这里可以养好习惯,将关键字进行大写,然后将表名和列名进行小写。...使用空格 在处理SQL语句时,其中所有空格都被忽略。SQL语句可以在一行上给出,也可以分成许多行。多数SQL开发人员认为将SQL语句分成多行更容易阅读和调试。 检索多个列: 在这里面通过逗号隔开。...虽然使用通配符可能会使你自己省事,不用明确列出所需列,但检索不需要的列通常会降低检索和应用程序的性能。 如果想检测出不同的行,那么可以使用ditinct,这样会进行去重。...所以在写code中,最好使用offset 这个关键字,工程以通用为第一要素。 有一个问题,假设有两张表都有列名a1。

    57420

    Oracle查询用户所有表

    ,视图等 select * from user_tab_comments -- 查询本用户的表,视图等 select * from all_col_comments --查询所有用户的表的列名和注释.... select * from user_col_comments -- 查询本用户的表的列名和注释 select * from all_tab_columns --查询所有用户的表的列名等信息(详细但是没有备注...如何在oracle中查询所有用户表的表名、主键名称、索引、外键等 1、查找表的所有索引(包括索引名,类型,构成列): select t....4、查找表的外键(包括名称,引用表的表名和对应的键名,下面是分成多步查询): select * from user_constraints c where c.constraint_type...= 外键名称 查询引用表的键的列名:select * from user_cons_columns cl where cl.constraint_name = 外键引用表的键名 5、查询表的所有列及其属性

    3.4K10

    【重学 MySQL】十四、显示表结构

    有几种方式可以显示MySQL中的表结构,下面是一些常用的方法: 使用DESCRIBE或DESC命令 DESCRIBE命令(或其简写形式DESC)是查看表结构最直接和常用的方法。...它会列出表的列名、数据类型、是否允许为空、键信息、默认值以及其他额外信息(如果有的话)。...你可以通过查询information_schema数据库中的COLUMNS表来获取特定表的列信息。...这个查询会返回表的列名、数据类型、是否允许为空、默认值、键信息(如主键、外键)以及额外信息(如自增)。...SHOW CREATE TABLE 表名; 这个命令会返回创建该表的完整SQL语句,包括所有的列定义、索引、外键约束等。这对于理解表的完整结构或复制表结构到其他数据库非常有用。

    17910

    MySql事务、索引和备份

    (1)概念 索引是一种数据库对象,是对数据库表中一列或多列的值进行排序的一种结构,使用索引可快速访问数据库表中的特定信息,也就是提高数据查询的效率。...此外,索引还可以加速表和表之间的连接,实现表与表之间的参照完整性;使用分组和排序子句进行数据检索时,可以显著减少分组和排序的时间。...       #  PRIMARY KEY(`GradeID`)    ); (2)唯一索引(unique) 唯一键是避免同一个表中某数据列中的值重复,与主键不同只能有一个不同,唯一键可有多个。...和 InnoDB 存储引擎均支持全文索引; (3)只有字段的数据类型为 char、varchar、text 及其系列才可以建全文索引; (4)适用于较大的数据集; (5)对于大容量的数据表,生成全文索引是一个非常消耗时间非常消耗硬盘空间的做法...(1)创建索引 直接创建 CREATE INDEX 索引名称 ON 表名( 字段名(长度) ); 创建表时添加; 建表后追加 ALERT TABLE 表名 ADD  索引类型 (数据列名); (2)删除索引

    51320

    01-03章 检索排序数据第1章 了解SQL第2章 检索数据第3章

    表(table) 某种特定类型数据的结构化清单,存储在表中的数据是同一种类型的数据或清单。 数据库中每个表都有唯一的名字标识自己,实际上是数据库名和表名等的组合。...表的特性定义数据在表中如何存储,存储哪类数据,数据如何分解,各部分信息如何命名等。 模式(schema)用来描述数据库中特定的表,也可以用来描述整个数据库(和其中表的关系)。...屏幕快照 2018-05-28 06.24.07.png 说明 如果没有要求排序查询结果,则返回的数据没有特定的顺序。 以上SELECT语句将返回表中所有行,数据没有过滤。...SQL关键字应大写,列名和表名应小写。 2.3 检索多个列 在SELECT关键字后给出多个列名,列名之间必须以逗号分隔。...因此,表示(如把上面的价格值显示为正确的十进制数值货币金额)一般在显示该数据的应用程序中规定。 2.4 检索所有列 SELECT语句可以检索所有的列,在实际列名的位置使用星号(*)通配符。

    2.6K10

    数据库系统与数据挖掘的区别_数据挖掘与大数据的关系

    3、基本表的创建、修改和撤消 基本表的创建:(可理解为建立表结构) CREAT TABLE SQL 模式名.基本表名 (列名,类型, …… 完整性约束…) 完整性约束包括主键子句(PRIMARY KEY...2、数据删除: DELETE FROM 基本表名 [WHERE条件表达式] 3、数据修改: UPDATE 基本表名 SET 列名=值表达式,[列名=值表达式…] [WHERE 条件表达式] 这一节的关于增删改的操作要和前面关于数据库模式...还有应该了解的是,函数依赖是否成立是不可证明的,只能通过属性的含义来判断,上述表是一个关系实例,可以一条条进行验证,但是对于模式设计来说,开始时并没有数据插入,我们只能从属性的含义出发,如这个关系模式保存了全校所有教师和课程对应关系...3、基本表的创建、修改和撤消 基本表的创建:(可理解为建立表结构) CREAT TABLE SQL 模式名.基本表名 (列名,类型, …… 完整性约束…) 完整性约束包括主键子句(PRIMARY KEY...还有应该了解的是,函数依赖是否成立是不可证明的,只能通过属性的含义来判断,上述表是一个关系实例,可以一条条进行验证,但是对于模式设计来说,开始时并没有数据插入,我们只能从属性的含义出发,如这个关系模式保存了全校所有教师和课程对应关系

    1.2K60

    MySQL 系列教程之(七)DQL:从 select 开始丨【绽放吧!数据库】

    如果在最后一个列名后加了逗号,将出现错误。 检索所有列 select * from user 使用通配符 一般,除非你确实需要表中的每个列,否则最好别使用*通配符。...使用子句的次序不对将产生错误消息 过 滤 数 据 WHERE 数据库表一般包含大量的数据,很少需要检索表中所有行。 通常只会根据特定操作或报告的需要提取表数据的子集。...常见的用途包括在实际的表列名包含不符合规定的字符(如空格)时重新命名它,在原来的名字含混或容易误解时扩充它,等等。...使用这些函数,MySQL查询可用于检索数据,以便分析和报表生成 确定表中行数(或者满足某个条件或包含某个特定值的行数)。 获得表中行组的和。...这使我们能够对行进行计数,计算和与平均数,获得最大和最小值而不用检索所有数据 目前为止的所有计算都是在表的所有数据或匹配特定的WHERE子句的数据上进行的。

    3.6K43

    索引恢复备份

    (Consistency) 隔离性(Isolation) 持久性(Durability) 改变自动提交模式 MySQL中默认是自动提交 SET AUTOCOMMIT = 0;   # 关闭自动提交模式...,实现表与表之间的参照完整性 使用分组和排序子句进行数据检索时,可以显著减少分组和排序的时间 全文检索字段进行搜索优化 分类 主键索引(PRIMARY KEY) 作用 某一个属性或属性的组合能唯一标识一条记录...特点 最常见的索引类型 确保数据记录的唯一性 确定特定数据记录在数据库中的位置 唯一索引(UNIQUE) 作用 避免同一个表中某数据列中的值重复 常规索引(INDEX) 作用 快速定位特定数据 index...和key关键字都可设置常规索引 应加在查找条件的字段 不宜添加太多常规索引,影响数据的插入、删除和修改操作 全文索引(FULLTEXT) 一般不用 管理索引 创建索引 ALERT TABLE 表名 ADD...索引类型(数据列名) 删除索引 DROP  INDEX 索引名 ON   表名 ALTER TABLE 表名   DROP  INDEX 索引名 ALTER TABLE 表名   DROP  PRIMARY

    49620

    面向对象(二十九)-MySql

    其他类型的数据存储,可以使用,如获取文件系统上的文件或内存中的大的哈希表,但数据并写入不会那么快,但这些类型的系统易于使用。...所以今天,我们使用关系数据库管理系统(RDBMS)来存储和管理体积庞大的数据。这就是所谓关系数据库,因为所有的数据存储到不同的表和关系建立使用主键或外键等其它键。...向表中插入数据 insert 语句可以用来将一行或多行数据插到数据库表中, 使用的一般形式如下: insert [into] 表名 [(列名1, 列名2, 列名3, ...)] values (值1,...查询表中的数据 select 语句常用来根据一定的查询规则到数据库中获取数据, 其基本的用法为: select 列名称 from 表名称 [查询条件]; 例如要查询 students 表中所有学生的名字和年龄..., 语句: select * from students; 2.1按特定条件查询: where 关键词用于指定查询条件, 用法形式为: select 列名称 from 表名称 where 条件; 以查询所有性别为女的信息为例

    1.6K10

    MySQL(二)数据的检索和过滤

    column from table; 该SQL语句的检索结果将返回表中的所有行,数据没有过滤(过滤将得出结果集的一个子集),也没有排序(如没有明确排序查询结果,则返回数据的顺序没有特殊意义,只要返回相同数目的行...; 在检索多个列时,要在列名之间加上逗号(,),最后一个列名不用加 SQL语句一般返回原始的、无格式的数据,数据的格式只是一个表示问题,而不是检索问题;因此表示方式一般在显示该数据的应用程序中规定,一般很少使用实际检索出的原始数据...(没有应用程序提供的格式) 3、检索所有列 select * from table; 给定通配符*,则检索数据时返回表中所有列 一般除非确实需要检索表中的每个列,否则最好别使用*通配符;虽然使用*可能自己比较省事...) 6、使用完全限定的表名 select table.column from database.table; 该SQL语句中检索的表名以及列名是完全限定的 二、排序检索数据 子句(clause):SQL...1告诉MySQL只返回一行的数据 三、过滤数据 数据库包含大量的数据,很少需要检索表中所有航,通常会根据特定操作或报告需要提取表数据的子集; 只检索所需数据需要指定搜索条件(search criteria

    4.1K30

    MySQL 教程上

    如何测试计算 SELECT提供了测试和试验函数与计算的一个很好的办法。虽然SELECT通常用来从表中检索数据,但可以省略FROM子句以便简单地访问和处理表达式。...INSERT SELECT 中的列名 为简单起见,这个例子在 INSERT 和 SELECT 语句中使用了相同的列名。但是,不一定要求列名匹配。事实上,MySQL 甚至不关心SELECT 返回的列名。...删除表的内容而不是表 DELETE 语句从表中删除行,甚至是删除表中所有行。但是,DELETE不删除表本身。 更快的删除 如果想从表中删除所有行,不要使用 DELETE。...CREATE TABLE 表名; 修改表字段 ALERT table 表名 ADD 列名 列类型; // 添加新列 ALERT table 表名 DROP COLUMN 列名; // 删除列 ALERT...table 表名 MODIFY 列名 列类型; // 仅修改列类型 ALERT table 表名 CHANGE 原列名 新表名 新类型 // 修改列类型及名称 FIRST 和 AFTER 关键字可用于

    3.4K10

    【MySQL】:约束全解析

    本文将深入介绍MySQL中的各种约束类型及其使用方法,包括非空约束、唯一约束、主键约束、默认约束、检查约束和外键约束,以及如何在创建表和修改表时添加约束,以及外键约束的相关知识。 一....[CONSTRAINT] [外键名称] FOREIGN KEY (外键字段名) REFERENCES 主表 (主表列名) ); ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN...KEY (外键字段名)REFERENCES 主表 (主表列名) ; 删除外键 ALTER TABLE 表名 DROP FOREIGN KEY 外键名称; 3.3 删除/更新行为 添加了外键之后,再删除父表数据时产生的约束行为...(外键字段) REFERENCES 主表名 (主表字段名) ON UPDATE CASCADE ON DELETE CASCADE; ️全篇总结 本文详细介绍了MySQL中的各种约束类型及其语法,包括约束的概念...通过学习本文,读者可以掌握如何在数据库设计和管理中灵活运用约束,从而保证数据的完整性和准确性,提高数据库的稳定性和安全性。

    28310

    【重学MySQL】十三、基本的 select 语句

    FROM table_name WHERE condition; SELECT:指定要从表中检索的列名。你可以指定一个或多个列名,或者使用星号(*)来检索表中的所有列。...FROM:指定要从中检索数据的表名。 WHERE(可选):指定用于过滤结果的条件。只有满足条件的行才会被检索出来。如果省略了WHERE子句,那么会检索表中的所有行。...检索所有列 SELECT * FROM Employees; 这条语句会检索Employees表中的所有列和所有行。...着重号 在MySQL中,“着重号”(通常指的是反引号`)主要用于标识符(如数据库名、表名、列名等)的引用,特别是在这些标识符是MySQL的保留字或者包含特殊字符(如空格、连字符等)时。...SQL是大小写不敏感的,但出于可读性和一致性考虑,推荐使用特定的命名约定(如关键字大写,表名和列名小写)。

    17610

    SQL笔记(2)——MySQL的表操作与索引

    可以使用DESCRIBE命令,该命令可以显示出表中所有列的名称、数据类型、默认值、空值约束、键约束等信息。...注意:column_type是必须的。在SQL中,修改表中某一列的数据类型是一个重要的操作,因为数据类型决定了该列可以存储的数据种类和范围。...Q&A 表结构中的Extra是什么意思 MySQL表结构中的Extra字段是用于显示额外的信息和注释,该字段提供了一些重要的信息,例如自增、默认值、主键信息等。...MUL:非唯一索引,该索引包括多个重复的键值时,Key属性值就会显示为mul。 UNI: 表示该列是唯一键。唯一键也可以用于唯一标识表中的每一行数据,但是它允许NULL值。一个表可以有多个唯一键。...它可以提高数据库查询的速度,基本原理是使用空间换取时间,将索引存储在磁盘上的文件中以加快读写速度。使用索引可以对表中的一列或多列的值进行排序,从而快速访问表中的特定信息。

    1.7K20

    SQL快速入门 ( MySQL快速入门, MySQL参考, MySQL快速回顾 )

    目录 检索 过滤检索结果 数据汇总处理 分组 给检索结果排序 表操作 插入数据 更新删除数据 子查询-迭代查询 联结-关联多个表 组合查询 视图 其它 检索 检索某表中单个列: SELECT 列名...FROM 表名; 检索某表中多个列: SELECT 列名,列名,列名 FROM 表名; 检索某表中所有列:(尽量不用) SELECT * FROM 表名; 只检索某表中某列里不重复的项: SELECT...DISTINCT 列名 (如果有两列或以上,需要这些列组合起来是不重复的) FROM 表名; 检索指定行数: SELECT 列名 FROM 表名 LIMIT 5 OFFSET n; (mySQL...WHERE prod_price = 3.49;(和字符串比较加单引号,数值不用) 查找列名为prod_name和列名为prod_price的两列,检索其中prod_price = 3.49...FOREIGN KEY 外键约束,一个表中的 FOREIGN KEY 指向另一个表中的 PRIMARY KEY。 CHECK 检查约束,用于限制列中的值的范围。

    2.2K20

    SQL快速入门 ( MySQL快速入门, MySQL参考, MySQL快速回顾 )

    SQL 目录 检索 过滤检索结果 数据汇总处理 分组 给检索结果排序 表操作 插入数据 更新删除数据 子查询-迭代查询 联结-关联多个表 组合查询 视图 其它 检索 检索某表中单个列: SELECT 列名...FROM 表名; 检索某表中多个列: SELECT 列名,列名,列名 FROM 表名; 检索某表中所有列:(尽量不用) SELECT * FROM 表名; 只检索某表中某列里不重复的项: SELECT...DISTINCT 列名 (如果有两列或以上,需要这些列组合起来是不重复的) FROM 表名; 检索指定行数: SELECT 列名 FROM 表名 LIMIT 5 OFFSET n; (MySQL中,选第...WHERE prod_price = 3.49;(和字符串比较加单引号,数值不用) 查找列名为prod_name和列名为prod_price的两列,检索其中prod_price = 3.49...FOREIGN KEY 外键约束,一个表中的 FOREIGN KEY 指向另一个表中的 PRIMARY KEY。 CHECK 检查约束,用于限制列中的值的范围。

    1.5K10
    领券