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

PostgreSQL 教程

PostgreSQL 基础教程 首先,您将学习如何使用基本数据查询技术从单个表中查询数据,包括查询数据、对结果集进行排序和过滤行。然后,您将了解高级查询,例如连接多个表、使用集合操作以及构造子查询。...最后,您将学习如何管理数据库表,例如创建新表或修改现有表的结构。 第 1 节. 查询数据 主题 描述 简单查询 向您展示如何从单个表中查询数据。 列别名 了解如何为查询中的列或表达式分配临时名称。...连接多个表 主题 描述 连接 向您展示 PostgreSQL 中连接的简要概述。 表别名 描述如何在查询中使用表别名。 内连接 从一个表中选择在其他表中具有相应行的行。...左连接 从一个表中选择行,这些行在其他表中可能有也可能没有对应的行。 自连接 通过将表与自身进行比较来将表与其自身连接。 完全外连接 使用完全连接查找一个表中在另一个表中没有匹配行的行。...EXCEPT 返回第一个查询中未出现在第二个查询的输出中的行。 第 6 节. 分组集、多维分组和汇总 主题 描述 分组集 在报告中生成多个分组集。

59210

PostgreSQL中的查询简介

JOIN子句可用于组合查询结果中两个或多个表的行。它通过在表之间查找相关列并在输出中适当地对结果进行排序来实现此目的。...,所以前面的示例通过在列的名称前面加上表的名称和句点来指定从哪个表中选择每个列。...对于任何查询,您可以指定从哪个表中选择一个列,如同在任何查询中一样,尽管从单个表中进行选择时没有必要,正如我们在前面的部分中所做的那样。让我们使用我们的示例数据来演示一个示例。...这意味着它选择在两个表中具有匹配值的所有记录并将它们打印到结果集,而排除任何不匹配的记录。...请注意,当使用UNION从多个表查询多个列时,每个SELECT语句必须查询相同数量的列,相应的列必须具有相似的数据类型,并且每个SELECT语句中的列必须具有相同的顺序。

12.4K52
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    分布式 PostgreSQL 集群(Citus),分布式表中的分布列选择最佳实践

    为了比较,订单表上的 status 字段具有 新(new)、已付款(paid) 和 已发货(shipped) 值,是分布列的一个糟糕选择,因为它只假设这几个值。...不同值的数量限制了可以保存数据的分片数量以及可以处理数据的节点数量。在具有高基数的列中,最好另外选择那些经常用于 group-by 子句或作为 join 键的列。 选择分布均匀的列。...数据共存的原理是数据库中的所有表都有一个共同的分布列,并以相同的方式跨机器分片,使得具有相同分布列值的行总是在同一台机器上,即使跨不同的表也是如此。...为了确保共置,即使在重新平衡操作之后,具有相同哈希范围的分片也始终放置在同一个节点上,这样相等的分布列值始终位于跨表的同一个节点上。 我们发现在实践中运行良好的分布列是多租户应用程序中的租户 ID。...在 Citus 中,具有相同分布列值的行保证在同一个节点上。分布式表中的每个分片实际上都有一组来自其他分布式表的位于同一位置的分片,这些分片包含相同的分布列值(同一租户的数据)。

    4.5K20

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

    任何列作为主键的条件: 任意两行都不具有相同的主键值; 每一行都必须具有一个主键值(主键列不允许NULL值); 主键列中的值不允许修改或更新; 主键值不能重用(某行从表中删除,它的主键不能赋给以后的新行...第2章 检索数据 2.1 SELECT语句 用于从一个或多个表中检索信息,必须指定两条信息,想选择什么,从什么地方选择。...关键字(keyword) 作为SQL组成部分的保留字,关键字不能用作表或列的名字。 2.2 检索单个列 用SELECT语句从Products表中检索名为prod_name的列。...下面代码检索 3 个列,按其中两个列对结果进行排序,首先按价格,然后按名称排序。...屏幕快照 2018-05-25 06.04.04.png 对于上述例子中的输出,仅在多个行具有相同的 prod_price 值时才对产品按prod_name 进行排序。

    2.6K10

    如何管理SQL数据库

    选择数据库 在创建表之前,首先必须告诉RDBMS您要在其中创建表的数据库。...在MySQL和MariaDB中,使用以下语法执行此操作: USE database; 在PostgreSQL中,您必须使用以下命令选择所需的数据库: \connect database 创建表 以下命令结构使用名称创建一个新表...执行基本查询 要查看表中单个列的所有数据,请使用以下语法: SELECT column FROM table; 要查询同一个表中的多个列,请使用逗号分隔列名: SELECT column_1, column..._2 DESC; 使用JOIN子句查询多个表 JOIN子句用于创建组合来自两个或多个表的行的结果集。...INNER JOIN将返回两个表中具有匹配值的所有记录,但不会显示任何没有匹配值的记录。 通过使用外部 JOIN子句,可以从两个表中的一个表中返回所有记录,包括在另一个表中没有相应匹配的值。

    5.5K95

    理解PG如何执行一个查询-1

    如果定义了一个有用的索引,该计划可能包括对整个表的顺序扫描和索引扫描。如果查询涉及两个或多个表,则规划器可推荐许多不同方法来连接这些表。执行计划是根据查询算子制定的。...例如,对整个表进行顺序扫描的成本计算为表中8K块的数量,加上一些CPU开销。 选择代价最低的执行计划后,查询执行器从计划的开头开始,并向最顶层的算子要结果集。每个算子将输入集转成结果集。...在树底部,Seq Scan操作只是从表中读取一行并将改行返回给父节点。Seq Scan操作扫描整个表后,左侧的Sort操作可以完成。左侧的Sort完成后,Merge Join算子将评估其右孩子。...首先,Seq Scan必须读取表中的每一行——它只能通过评估每一行的WHERE子句从结果集中删除行。如果您提供开始和/或结束值,索引扫描可能不会读取每一行。...Unique Unique算子从输入集中消除重复值。输入集必须按列排序,并且列必须唯一。

    2K20

    POSTGRESQL PG VS SQL SERVER 到底哪家强? (译) 应该是目前最全面的比较

    聚集索引根据键值(索引定义中的列)对表或视图中的数据行进行排序。一个表只能有一个聚集索引。非聚集索引存储在表数据之外,每个键值条目都有一个指向数据的指针。...SQL Server的identity列属性为表创建一个标识列,用于生成行的关键值。创建时指定两个值:seed(第一行的初始值)和increment(增加值相对于上一行)。...SQL Server中的计算列如果未标记为PERSISTED属性,则不会在表中物理存储;只有在值是确定的(或始终返回相同的结果)时,列才能被持久化。...MSSQL 中文:两种数据库在MVCC 数据一致性上的不同 PostgreSQL具有成熟的多版本并发控制(MVCC)系统来处理同时进行的多个过程。...在 SQL Server 中,当两个源表包含定义的关系且其中一个表中的项可以与另一个表中的项相关联时,可以创建嵌套表。这可以是两个表共享的唯一标识符。嵌套表对于分析数据非常有用。

    3K20

    扩展我们的分析处理服务(Smartly.io):使用 Citus 对 PostgreSQL 数据库进行分片

    它使从应用程序级别的迁移更容易,因为我们只需迁移此服务即可与 Citus 分片 PostgreSQL 一起使用。 分片数据库对数据库模式有一定的要求。模式必须具有一个作为分片条件的值。...分片逻辑使用此值来区分数据位于哪个分片上。在 Citus-PostgreSQL 中,分片是使用表主键控制的。...此复合主键包含一个或多个列,其中第一个定义的列用作分片值: ALTER TABLE ad_stats ADD PRIMARY KEY (account_id, ad_id, date); SELECT...这意味着单个帐户的数据位于单个表分片中。我们必须确保所有主键都采用这种格式,并且表中包含帐户 ID 信息。我们还必须更改一些外键和唯一性约束,因为它们还必须包含分片列。...从所有可能的分片中读取不会像从单个分片中读取那样有效。 此外,Citus 对您可以在分片表之间执行的 JOIN 类型有一定的限制。通常 JOIN 要求分片列出现在 JOIN 条件中。

    75830

    PostgreSQL 索引类型详解

    在单个表上,多个BRIN索引通常没有必要,除非需要使用不同的存储参数(pages_per_range)。...多索引组合优势: PostgreSQL 提供了能力来结合多个索引(包括同一索引的多次使用),以处理单个索引无法覆盖的查询情况。...默认情况下,唯一索引对空值不视为相同,因此允许多个空值存在于索引列中。使用 NULLS NOT DISTINCT 可以修改此行为,使得空值视为相同。...表达式的索引 索引列不必只是基础表的一列,还可以是从表的一列或多列计算得出的函数或标量表达式。此功能对于根据计算结果快速访问表非常有用。...也可以通过创建具有限制的唯一部分索引,在列中只允许一个 null。IS NULL 例 11.4.不要使用部分索引来替代分区 在数据库中,不应该通过创建大量非重叠的部分索引来替代分区。

    9510

    如何在Ubuntu 18.04上安装和使用PostgreSQL

    您还可以选择为每列添加表约束。...接下来的两个命令的设备分别创建type和color,其中每一个可以不为空。之后的命令会创建一个location列并创建一个约束,该约束要求该值为八个可能值之一。...例如,不要将列名包装在引号中,但是您输入的列值确实需要引号。 另外要记住的是,您不要为equip_id列输入值。这是因为只要创建表中的新行,就会自动生成此项。...列及其中的值,但保留所有其他数据。...更新表中的数据 到目前为止,您已经学习了如何向表中添加记录以及如何删除它们,但本教程尚未介绍如何修改现有条目。 您可以通过查询所需的记录并将列设置为您要使用的值来更新现有条目的值。

    5.5K60

    重磅 | 十年来扩展PostgreSQL的一些经验和教训

    在正常的PostgreSQL操作中,被更新删除或过时的元组不会从表中物理删除。它们将保持存在,直到完成VACUUM。因此,有必要定期进行VACUUM,尤其是在频繁更新的表上。...使用PostgreSQL表分区,您可以将一个表变成多个表,并且在您的应用程序中仍然只有一个表的外观。执行表分区时,需要考虑一些性能方面的考虑,因此在开始之前请进行研究。...实施保留策略时,使用简单DROP TABLE的方法从数据库中删除单个分区表,而不是尝试从整个表中进行有针对性的删除。此策略可以首先防止膨胀。该pg_partman扩展,甚至可以自动为你这个过程!...比方说,你有两个数据列的表,big_column和int_column。big_column每个记录中存储的数据通常约为1千字节,并且int_column更新非常频繁。...在该单独的表中更新它时,不会big_column生成任何重复项。尽管拆分这些列意味着您需要使用一个JOIN来访问两个表,但是根据您的用例,可能值得权衡取舍。

    1.6K20

    SqlAlchemy 2.0 中文文档(二)

    另请参阅 表值、表和列值函数、行和元组对象 - 在 PostgreSQL 文档中。 虽然许多数据库支持表值和其他特殊形式,但 PostgreSQL 往往是对这些功能需求最大的地方。...PostgreSQL 支持的 json_each() JSON 函数来生成一个具有单列(称为 value)的表值表达式,并选择了其三行中的两行。...另请参阅 表值、表值和列值函数、行和元组对象 - 在 PostgreSQL 文档中。 虽然许多数据库支持表值函数和其他特殊形式,但 PostgreSQL 往往是对这些功能需求最多的地方。...#### 列值函数 - 表值函数作为标量列 PostgreSQL 和 Oracle 支持的一种特殊语法是在 FROM 子句中引用函数,然后在 SELECT 语句或其他列表达式上下文中将其自身作为单个列传递...另请参阅 表值、表和列值函数、行和元组对象 - 在 PostgreSQL 文档中。 虽然许多数据库支持表值和其他特殊形式,但 PostgreSQL 往往是这些特性需求最大的地方。

    45510

    Citus 分布式 PostgreSQL 集群 - SQL Reference(创建和修改分布式表 DDL)

    此示例将创建总共 citus.shard_count 个分片,其中每个分片拥有一部分哈希令牌空间并根据默认的 citus.shard_replication_factor 配置值进行复制。...上述方法将表分布到多个水平分片中,但另一种可能是将表分布到单个分片中并将分片复制到每个工作节点。...以这种方式分布的表称为引用表。它们用于存储集群中多个节点需要频繁访问的数据。 引用表的常见候选包括: 较小的表需要与较大的分布式表连接。 多租户应用程序中缺少租户 ID 列或不与租户关联的表。...(在某些情况下,为了减少迁移工作,用户甚至可以选择从与租户关联但当前缺少租户 ID 的表中创建引用表。) 需要跨多个列的唯一约束并且足够小的表。...如果您不关心表的 co-location,请忽略此参数。它默认为 'default' 值,它将表与具有相同分布列类型、分片计数和复制因子的任何其他默认 co-location 表分组。

    2.8K20

    POSTGIS 总结

    如果两个相同类型的几何图形具有相同的x、y坐标值,即如果第二个图形与第一个图形的坐标信息相等(相同),则ST_Equals()返回TRUE。...为了弄清楚要处理的数据的大概内容(读取表的一小部分信息,而不是读取表的大部分信息),PostgreSQL保存每个索引列中数据分布的统计信息。默认情况下,PostgreSQL定期收集统计信息。...发出VACUUM命令不会更新数据库统计信息;同样,执行ANALYZE命令也不会清理未使用的表空间。这两个命令都可以针对整个数据库、单个表或单个列运行。...上面的第一个函数签名传入现有的栅格数据作为新创建栅格的模板,会返回具有相同元数据(没有波段、没有像元值)的栅格数据。 在创建了一个空栅格之后,要向其添加波段,并可能要对其进行编辑。...MVT格式可以存储具有不同属性集的要素。要使用此功能,请在行数据中包含一个JSONB列,该列通过在一级深度下包含多个Json对象来存储多个不同属性集。JSONB中的键和值将被编码为要素属性。

    6.2K10

    SqlAlchemy 2.0 中文文档(三十九)

    一些数据库,如 PostgreSQL,将这个概念进一步扩展为 模式搜索路径,在特定数据库会话中可以考虑多个模式名称为“隐式”;引用其中任何一个模式中的表名都不需要存在模式名称(与此同时,如果模式名称存在...最终的结果是,单个 MetaData 集合中将存在两个独立的表示实际数据库中同一表的 Table 对象。...覆盖反射列 在反射表时,可以使用显式值覆盖单个列;这对于指定自定义数据类型、在数据库中未配置的主键等约束非常方便: >>> mytable = Table( ......一些数据库(如 PostgreSQL)进一步将此概念扩展为“模式搜索路径”的概念,其中可以在特定数据库会话中将 多个 模式名称视为“隐式”; 指的是任何这些模式中的表名称将不需要模式名称存在(同时,如果模式名称存在...最终结果是,在实际数据库中表示同一张表的单个 MetaData 集合中将有两个单独的 Table 对象。

    42610

    SQL | SQL 必知必会笔记 (一 )

    列(column) 表中的一个字段,所有表都是有一个和 多个列组成 行(row) 表中的一个记录(record) 主键(primary key) 一列(或一组列),其值能够唯一标识表中每一行 关键字(...SQL 不区分大小写,但一般习惯关键字用大写,列名和表名使用小写。 处理 SQL 语句时,所有空格都会被忽略。一般认为写成多行更容易维护。 选择多个列时,一定要在列名之间加上逗号,但最后一个列名不加。...使用 SELECT 关键字检索表数据,必须给出想选择什么(SELECT)和从什么地方选择两条信息(FROM)。...第一个数字是检索的行数,第二个数字是指从哪儿开始。...NULL 表示空值,确定是否空值,不能简单的 = NULL,SELECT 语句有一个特殊的 WHERE 子句 IS NULL ,可用来检查具有 NULL 值的列。

    2.6K51

    列存zedstore

    对于某些压缩例如表编码或者delta编码,可以从压缩数据中直接构造元组。 列存 列存使用同样的结构,每列都是一个B-tree,以TID为索引值。所有列的B-tree存储到同一个物理文件中。...已压缩的元组原样添加到页,页面以压缩数据进行重写,压缩后页仍放不下,则发生分裂。 Toast:当字段值非常大时,分割成多个chunk,每个chunk存储到同一个物理文件的专门的一个toast页上。...Select:如果利用AM进行扫描,将property添加到表AM中。当利用这个字段通过AM进行表扫描时,执行器解析这个计划。利用目标列和等职查询所需的列。这个列表在beginscan中传递给AM。...Zedstore使用这个列投影列表从选择的列中拉取数据。使用虚拟元组表slot传递返回列子集。当前表am api需要在这里进行增强,以便将列投影传递给AM。...为了做到这些,仍需要进行碎片整理,并将页从文件尾部移动到头部,然后截断文件。 这个设计中,在page cache中仅缓存压缩页。

    2.1K40

    SQL必知必会总结1-第1到7章

    如果表中的列可以作为主键,则它必须满足: 任意两行都不具有相同的主键值(主键列不允许NULL值) 每行都必须有一个主键值 主键列中的值不允许修改或者更新 主键值不能重用(如果某行从表中删除,则它的主键不能赋给以后的行记录...它的语句都是由简单的、具有描述性的英文单词组成的 3、SQL虽然简单,但是实际上是一种很强有力的语言,灵活使用去语言元素,可以进行复杂和高级的数据库操作 检索数据 本章中介绍的是如何使用select语句从表中检索一个或者多个数据列...为了使用select检索数据,必须至少给出两个信息: 检索什么(字段,列) 从哪里检索(表) 检索单个列 SELECT prod_name -- 检索什么 FROM Products; -- 从哪里检索...AND...联合使用 空值检查 当我们创建表的时候,可以指定其中的列是否包含空值。在一个列不包含值时,称其包含空值NULL。...计算字段是运行时在select语句内创建的。 拼接字段 将多个字段联结在一起构成单个字段。根据不同的DBMS,使用+或者||来进行联结。但是在MySQL中必须使用特殊的函数来进行操作。

    2.5K31

    MOP 系列|MOP 三种主流数据库索引简介

    Oracle 索引类型 B 树索引 索引组织表 •索引组织表(IOT)在一个B树索引结构中存储表行的全部内容。使用索引组织表,能缩短 具有精确匹配和主键范围搜索的查询时间。...在索引扫描中,数据库使用语句指定的索引列值遍历索引来检索一行。如果数据库扫描索引寻找一个值,那么它将在 n 个 I/ o 中找到这个值,其中 n 是 B 树索引的高度。...对于表列中的每个值,索引存储索引表中对应行的行号。相比之下,标准位图索引是在单个表上创建的。 位图连接索引是通过提前执行限制来减少必须连接的数据量的有效方法。...,索引在与其表相同的列上进行分区,具有相同的分区数量和相同的分区边界。...每个索引分区只与基础表的一个分区相关联,因此索引分区中的所有键仅引用存储在单个表分区中的行。通过这种方式,数据库自动将索引分区与其关联的表分区同步,使每个表-索引对独立。

    15010

    GreenPlum中的数据库对象

    可能会安装有多个单独的Greenplum数据库系统,但是通常只会用环境变量设置选择其中一个。 一个Greenplum数据库系统中可以有多个数据库。...外键约束指定一列或者一组列中的值必须匹配出现在另一个表的某行中的值,以此来维护两个相关表之间的参照完整性。参照完整性检查不能在一个Greenplum数据库的分布表段之间实施。...在一个被频繁更新的列上建立索引会增加该列被更新时所要求的写操作数据量。 创建选择性的B-树索引。 索引选择度是一个列中具有的可区分值的数量除以表中行数得到的比例。...为低选择度的列使用位图索引。Greenplum数据库的位图索引类型在常规的PostgreSQL中不可用。 索引在连接中用到的列。...何时不用位图索引 不要为唯一列或者具有高基数数据的列使用位图索引,例如顾客姓名或者电话号码。位图索引的性能增益和磁盘空间优势在具有100,000或者更多唯一值的列上开始减小,这与表中的行数无关。

    84420
    领券