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

PostgreSQL 教程

LIMIT 获取查询生成的行的子集。 FETCH 限制查询返回的行数。 IN 选择与值列表中的任何值匹配的数据。 BETWEEN 选择值范围内的数据。 LIKE 基于模式匹配过滤数据。...连接删除 根据另一个表中的值删除表中的行。 UPSERT 如果新行已存在于表中,则插入或更新数据。 第 10 节....重命名表 将表的名称更改为新名称。 添加列 向您展示如何向现有表添加一列或多列。 删除列 演示如何删除表的列。 更改列数据类型 向您展示如何更改列的数据。 重命名列 说明如何重命名表中的一列或多列。...检查约束 添加逻辑以基于布尔表达式检查值。 唯一约束 确保一列或一组列中的值在整个表中是唯一的。 非空约束 确保列中的值不是NULL。 第 14 节....PostgreSQL 技巧 主题 描述 如何比较两个表 描述如何比较数据库中两个表中的数据。 如何在 PostgreSQL 中删除重复行 向您展示从表中删除重复行的各种方法。

59010

PostgreSQL中的查询简介

PostgreSQL,通常缩写为“Postgres”,是一种具有面向对象方法的关系数据库管理系统,这意味着信息可以表示为PostgreSQL模式中的对象或类。...在本节中,我们将解释并提供一些常用查询子句的示例。 除了FROM和WHERE之外,最常用的查询子句之一是GROUP BY子句。它通常在您对一列执行聚合函数时使用,但与另一列中的匹配值相关。...JOIN子句可用于组合查询结果中两个或多个表的行。它通过在表之间查找相关列并在输出中适当地对结果进行排序来实现此目的。...这意味着它选择在两个表中具有匹配值的所有记录并将它们打印到结果集,而排除任何不匹配的记录。...为了说明这个想法,让我们在每个表中添加一个新行,而另一个表中没有相应的条目: INSERT INTO tourneys (name, wins, best, size) VALUES ('Bettye

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

    【PostgreSQL 】PostgreSQL 12的8大改进,性能大幅度提升

    现在,通过更有效地利用空间,多列索引大小最多可减少40%,从而节省了磁盘空间。具有重复项(非唯一B树索引)的索引的性能得以提高,并且从索引中删除元组(行)的真空运行效率更高。...以俄亥俄州辛辛那提为例-您有一个标记为“城市”的字段,另一字段称为“州”,其中“辛辛那提”位于一列,而俄亥俄州则在另一列。俄亥俄州的辛辛那提市将相当普遍,但亚利桑那州的辛辛那提市却很少见。...4.公用表表达式(CTE) 正确实现的另一个过期功能是通用表表达式(带有查询内联)。公用表表达式充当优化障碍,公用表表达式中的查询首先执行,然后PostgreSQL将在查询中执行之后的任何操作。...在PostgreSQL 12中,通过一个称为“ pg checksums”的命令(以前称为pg verify checksum),用户可以在不转储和重新加载数据的情况下将群集从无校验和更改为校验和。...长期以来要求的功能很难开发,但最终在PostgreSQL 12中交付。 升级到PostgreSQL 12 这八个功能只是PostgreSQL 12中许多改进中的几个。

    3.1K20

    开源OLAP系统的比较:ClickHouse、Druid和Pinot

    在Druid中,元数据也保留在SQL数据库中,在本文下面的“ Druid与Pinot之间的区别”部分中对此进行了详细说明。...集合立即转换为列格式。每个ClickHouse节点上都有一个后台进程,该进程将行集合并为较大的行集。...查询执行 Druid和Pinot具有称为“代理”的专用节点层,它们接受对系统的所有查询。它们基于从段到加载段的节点的映射,确定应向哪些“历史”查询处理节点发出子查询。代理将此映射信息保留在内存中。...每行的相对重要性对于不同的应用程序是不同的,但是如果您的应用程序由表中一列的许多属性描述,而由另一列的无或几个属性描述,则很可能应该从列标题中选择相应的系统。...将SQL数据库作为依赖项的弊端是更大的操作负担,尤其是在组织中尚未建立某些SQL数据库的情况下。Druid支持MySQL和PostgreSQL,Microsoft SQL Server有一个社区扩展。

    2.6K21

    Greenplum 实时数据仓库实践(3)——Greenplum与数据仓库

    从一般角度说,行存具有更广泛的适用性,列存对于一些特定的业务场景可以节省大量I/O资源以提升性能,也可以提供更好的压缩效果。...不可重复读:一个事务两次读取同一行得到不同的结果,因为另一个并发事务在这个事务开始后提交了更改。 幻读:在同一事务中执行两次查询可以返回两组不同的行,因为另一个并发事务添加了行。...在read committed隔离模式下,如果另一个并发事务自事务开始以来已提交更改,则在事务中检索两次的行中的值可能不同。...stakindN列中的每一列都包含一个数字代码,用于描述存储在其槽位中的统计信息的类型。从1到99的stakind代码是为PostgreSQL数据类型保留的。...例如,某些查询可以通过为特定列,尤其是分布不规则的列增加目标值以提高性能。如果将一列的目标值设置为0,ANALYZE将忽略该列。

    4.6K20

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

    在顺序扫描完成构建其中间结果集后,它被送入计划的下一步。这个特定计划的最后一步是排序操作,它是满足我们的ORDER BY子句所必需的。...在树底部,Seq Scan操作只是从表中读取一行并将改行返回给父节点。Seq Scan操作扫描整个表后,左侧的Sort操作可以完成。左侧的Sort完成后,Merge Join算子将评估其右孩子。...首先,Seq Scan必须读取表中的每一行——它只能通过评估每一行的WHERE子句从结果集中删除行。如果您提供开始和/或结束值,索引扫描可能不会读取每一行。...Unique通过将每一行的唯一列与前一行进行比较来工作。如果值相同,则从结果集中删除重复项。Unique算子仅删除行,不会删除列,也不会更改结果集的顺序。...Unique可以在处理完输入集之前返回结果集中的第一行。计划器/优化器使用Unique算子来满足DISTINCT子句。Unique还用于消除UNION中的重复项。

    2K20

    DBLog:一种基于水印的变更数据捕获框架(论文翻译)

    现有的解决方案以不同的方式处理这个问题,并具有不同的权衡: Databus [^8]具有一个引导服务,它从源中读取事务日志事件并将它们存储在一个单独的数据库中。...每次执行一批数据行的采集操作后,DBLog会将最后一行数据的主键值存储在Zookeeper中,以便后续可以在该点暂停或恢复操作。 算法1描述了基于水印的方法来选择下一个特定表的块。...在图3b中,我们重点介绍了从结果集中删除的选定块行,这些行对于在水印之间出现的主键进行了排除(步骤5到7)。...在PostgreSQL中,wal2json包含列名和类型以及列值。在MySQL中,模式更改增量作为binlog事件接收。...通过分块执行表上的选择操作并将获取的行与日志事件交错,从而实现这一点,以使两者均能进展。同时,由于基于水印的方法,始终保留原始历史记录的顺序,而无需在源数据库上使用锁。

    60250

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

    列表分区将表按显式列出的预定义键值分组,每个分区中都出现这些键值。 SQL Server SQL Server支持表和索引分区。数据在水平方向上被分区,并将一组行映射到单个分区。...同义词属于一个模式,并且像模式中的其他对象一样,它的名称必须是唯一的。绑定只是根据名称进行的;如果基础对象被修改、删除或替换,那么在运行时将会发现缺失的引用。Postgresql不支持同义词。...MSSQL 中文:两种数据库在表操作中的不同 Truncate 在PostgreSQL中,TRUNCATE命令可以删除一组表中的所有行。...例如:TRUNCATE customers; 在SQL Server中,TRUNCATE TABLE命令删除表中的所有行或指定分区的行,类似于没有WHERE子句的DELETE语句。...这种方式可以方便地存储和读取嵌套的数据结构。 在 SQL Server 中,当两个源表包含定义的关系且其中一个表中的项可以与另一个表中的项相关联时,可以创建嵌套表。这可以是两个表共享的唯一标识符。

    3K20

    我赌你工作中必用的vim操作快捷键

    删除光标所在的向下 n 列,例如 20dd 则是删除 20 列 (常用) d1G 删除光标所在到第一行的所有数据 dG 删除光标所在到最后一行的所有数据 d$ 删除游标所在处,到该行的最后一个字符 d0...那么原本的第 20 行会被推到变成 30 行。 (常用) J 将光标所在列与下一列的数据结合成同一列 c 重复删除多个数据,例如向下删除 10 行,[ 10cj ] u 复原前一个动作。...[Esc] 退出编辑模式,回到一般模式中(常用) 第三部份:一般模式切换到指令列模式的可用的按钮说明 指令列的储存、离开等指令 :w 将编辑的数据写入硬盘档案中(常用) :w!...在 vi 当中,常常具有『强制』的意思~ :wq 储存后离开,若为 :wq! 则为强制储存后离开 (常用) ZZ 这是大写的 Z 喔!...:w [filename] 将编辑的数据储存成另一个档案(类似另存新档) :r [filename] 在编辑的数据中,读入另一个档案的数据。

    1K41

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

    在阅读方面,我们既支持事务发送(即,以特定的参与里程碑发送给特定的订户),也可以发送给具有特定特征的大量受众(即细分受众群)。...更新是PostgreSQL中another肿的另一个来源,因为更新是通过DELETE加号实现的INSERT。即使删除在数据集上并不常见,但严重更新的表也可能成为受害者。...在正常的PostgreSQL操作中,被更新删除或过时的元组不会从表中物理删除。它们将保持存在,直到完成VACUUM。因此,有必要定期进行VACUUM,尤其是在频繁更新的表上。...在这种情况下,您可以做的是将工作拆分int_column到一个单独的表中。在该单独的表中更新它时,不会big_column生成任何重复项。...XID环绕 在我们旅途的早期,另一个问题导致了一些服务丢失:一种称为事务ID(也称为TXID或XID)的回绕预防故障模式。 PostgreSQL的MVCC实现依赖于32位事务ID。

    1.6K20

    GreenPlum中的数据库对象

    2.6.删除一个数据库 DROP DATABASE命令删除一个数据库。它会移除该数据库的系统目录项并且删除该数据库在磁盘上的目录及其中包含的数据。...利用表空间可以控制PostgreSQL的磁盘布局,它有两方面的优势: 首先,如果集群中的某个分区超出初始空间,可以在另一个分区上创建新的表空间并使用。后期可以重新配置系统。...外键约束指定一列或者一组列中的值必须匹配出现在另一个表的某行中的值,以此来维护两个相关表之间的参照完整性。参照完整性检查不能在一个Greenplum数据库的分布表段之间实施。...使用压缩存储 列存储表具有压缩优势。 在CREATE TABLE时使用WITH子句指定表的存储模式。...如果结果行数很小,查询能够在不做全表扫描的情况下很快地被回答。 何时不用位图索引 不要为唯一列或者具有高基数数据的列使用位图索引,例如顾客姓名或者电话号码。

    84420

    数据库PostrageSQL-日常数据库维护工作

    PostgreSQL中的备份和恢复机制在Chapter 25中有详细的介绍。 另一种主要类型的维护任务是周期性地“清理”数据库。该活动在Section 24.1中讨论。...与之相关,更新将被查询规划器使用的统计信息的活动将在Section 24.1.3中讨论。另一项需要周期性考虑的任务是日志文件管理。这在Section 24.3中讨论。...例如,一个包含行被更新时间的timestamp列将在行被增加和更新时有一直增加的最大值;这样一列将可能需要更频繁的统计更新,而一个包含一个网站上被访问页面 URL 的列则不需要。...因为PostgreSQL的索引不包含元组的可见性信息,一次普通的索引扫描会为每一个匹配的索引项获取堆元组,用来检查它是否能被当前事务所见。另一方面,一次只用索引的扫描会首先检查可见性映射。...在9.4之前的PostgreSQL版本中,实际上会通过将一行的插入 XID 替换为FrozenTransactionId来实现冻结,这种FrozenTransactionId在行的 xmin系统列中是可见的

    1.7K21

    如何在CentOS 7上安装PostgreSQL关系数据库

    截至本文发布,PostgreSQL 9.6.3是CentOS 7的最新版本,但这些步骤可应用于任何基于RPM的安装。 注意使用此方法安装Postgres时,版本号包含在其配置目录中。...使用表 PostgreSQL数据库使用表来存储和组织数据库中的信息。在本节中,您将找到添加,删除和操作表的实际示例。...有关支持的数据类型的完整说明,请参阅PostgreSQL文档。 添加和更新行 在本节中,您将使用UPDATE在您创建的现有行中输入值。然后,你将创建一个全新的行INSERT。...在本节中,您将从表中删除一列,然后删除第二行。...以下命令将删除列中值为2的employee_id行: DELETE FROM employees WHERE employee_id = '2'; 3.

    4.5K20

    简单谈谈OLTP,OLAP和列存储的概念

    这里以零售数据仓库为例: 模式的中心是一个所谓的事实表,在本例中为fact_sales表,事实表的每一行表示在特定时间发生的事件,这里每一行代表客户购买的一个商品。...因此,如果你需要重新组装完整的行,你可以从每个单独的列文件中获取第 23 项,并将它们放在一起形成表的第 23 行。...这是因为列按照相同的顺序包含行,因此一列的位图中的第 k 位和另一列的位图中的第 k 位对应相同的行。...注意,对每列分别执行排序是没有意义的,因为那样就没法知道不同列中的哪些项属于同一行。我们只能在明确一列中的第 k 项与另一列中的第 k 项属于同一行的情况下,才能重建出完整的行。...这将有助于需要在特定日期范围内按产品对销售进行分组或过滤的查询。 按顺序排序的另一个好处是它可以帮助压缩列。如果主要排序列没有太多个不同的值,那么在排序之后,将会得到一个相同的值连续重复多次的序列。

    3.9K31

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

    Oracle 索引类型 B 树索引 索引组织表 •索引组织表(IOT)在一个B树索引结构中存储表行的全部内容。使用索引组织表,能缩短 具有精确匹配和主键范围搜索的查询时间。...函数索引 function-based index 基于函数的索引计算涉及一个或多个列的函数或表达式的值,并将其存储在索引中。基于函数的索引既可以是 B 树索引,也可以是位图索引。...一种代替基于函数的索引的方法是在表中添加一个虚拟列,然后为虚拟列创建索引(11g 以上)。...PostgreSQL 的标准发布中包含了用于二维几何数据类型的 GiST操作符类,比如,一个图形包含另一个图形的操作符“@>”,一个图形在另一个图形的左边且没有重叠的操作符“中只包含那些符合该谓词的表行的项。部分索引是一种专门的特性, 但在很多种情况下它们也很有用。

    15010

    【22】进大厂必须掌握的面试题-30个Informatica面试

    2.如何删除Informatica中的重复记录?有多少种方法可以做到? 有几种删除重复项的方法。 如果源是DBMS,则可以使用Source Qualifier中的属性来选择不同的记录。 ?...将所有必需的端口传递到聚合器后,选择所有那些端口,您需要选择这些端口以进行重复数据删除。如果要基于整个列查找重复项,请按键将所有端口选择为分组。 ? 映射将如下所示。 ?...14.如何将唯一记录加载到一个目标表中,并将重复记录加载到另一目标表中?...在聚合器转换中,按关键字列分组并添加新端口。将其称为count_rec即可对键列进行计数。 从上一步将路由器连接到聚合器。在路由器中,分为两组:一组称为“原始”,另一组称为“重复”。...然后,将其余的列从源发送到一个路由器转换。 ? 在路由器中创建两个组,并给出如下条件: ? 对于新记录,我们必须生成新的customer_id。为此,请使用一个序列生成器,并将下一列连接到表达式。

    6.7K40
    领券