百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Postgres 9.5 新特性一览

wptr33 2025-03-04 14:19 12 浏览

得益于数据分组能力的增强,在Postgres中可以进行数据透视操作了;前提是你要清楚需要返回什么样的结果。

下面以一个部门员工信息例子进行简述。

SELECT department, role, gender, count(*)
FROM employees
GROUP BY your_grouping_type_here;

这是一个简单的按部门信息进行数据分组的例子。如果要Postgres实现更复杂的分组操作,该如何做呢?

grouping sets: 将返回每个特定key的计数。结果是你将得到每个部门的key值而同时其它key为null;返回的是根据部门key而得出的计数。

cube: 返回值与上述一样,但是每个单独的数据联合还会进行分组。所以得到的结果除了每个部门的合计数,还会得到部门与性别,部门与职位,部门与职位与性别的分组显示。

rollup: 类似于cube,但是只会返回具体指定的分组项。例如如果使用的分组项是roll (department, role, gender),那么你将不会得到部门与性别的独立分组显示。

导入外部schemas(数据泵)

如果你已经创建好外部数据库,那么可以透过导入的方式导入到Postgres中;你可以根据需要导入相应的数据表。

例如:

IMPORT FOREIGN SCHEMA public
FROM SERVER some_other_db INTO reference_to_other_db;

pg_rewind 如果你正在管理Postgres实例及正运行HA,那么pg_rewind将是好帮手。常规的数据复制操作是先下载物理数据库,然后进行数据传输。

如果操作失败,一般操作是进行回撤并重来。但是如果以pg_rewind模式进行则方便很多。它可以节省当发生错误时需要进行的大量数据移动操作。

Upsert Upsert是Postgres9.5的亮点之一。简单来说,当进行数据插入时出现冲突,你可以进行的操作是:

JSONB Postgres9.5对JSONB进行了更新。让我最兴奋的是它使得JSONB在psql中的输出更具可读性。

例如可以尝试运行如下语句,看看其输出结果如何:

SELECT jsonb_pretty(jsonb_column)
FROM foo;

更多的特性描述可以参考最新的RC。

原文出自:Craigkerstiens

相关推荐

十年之重修Redis原理(redis重试机制)

弱小和无知并不是生存的障碍,傲慢才是。--------面试者...

Redis 中ZSET数据类型命令使用及对应场景总结

1.zadd添加元素zaddkeyscoremember...

redis总结(redis常用)

RedisTemplate封装的工具类packagehk.com.easyview.common.helper;importcom.alibaba.fastjson.JSONObject;...

配置热更新系统(如何实现热更新)

整体设计概览┌────────────┐┌────────────────┐┌────────────┐│配置后台服务│--写入-->│Red...

java高级用法之:调用本地方法的利器JNA

简介JAVA是可以调用本地方法的,官方提供的调用方式叫做JNI,全称叫做javanativeinterface。要想使用JNI,我们需要在JAVA代码中定义native方法,然后通过javah命令...

SpringBoot:如何优雅地进行响应数据封装、异常处理

背景越来越多的项目开始基于前后端分离的模式进行开发,这对后端接口的报文格式便有了一定的要求。通常,我们会采用JSON格式作为前后端交换数据格式,从而减少沟通成本等。...

Java中有了基本类型为什么还要有包装类型(封装类型)

Java中基本数据类型与包装类型有:...

java面向对象三大特性:封装、继承、多态——举例说明(转载)

概念封装:封装就是将客观的事物抽象成类,类中存在属于这个类的属性和方法。...

java 面向对象编程:封装、继承、多态

Java中的封装(Encapsulation)、继承(Inheritance)和多态(Polymorphism)是面向对象编程的三大基本概念。它们有助于提高代码的可重用性、可扩展性和可维护性。...

怎样解析java中的封装(怎样解析java中的封装文件)

1.解析java中的封装1.1以生活中的例子为例,打开电视机的时候你只需要按下开关键,电视机就会打开,我们通过这个操作我们可以去间接的对电视机里面的元器件进行亮屏和显示界面操作,具体怎么实现我们并不...

python 示例代码(python代码详解)

以下是35个python代码示例,涵盖了从基础到高级的各种应用场景。这些示例旨在帮助你学习和理解python编程的各个方面。1.Hello,World!#python...

python 进阶突破——内置模块(Standard Library)

Python提供了丰富的内置模块(StandardLibrary),无需安装即可直接使用。以下是一些常用的内置模块及其主要功能:1.文件与系统操作...

Python程序员如何调试和分析Python脚本程序?附代码实现

调试和分析Python脚本程序调试技术和分析技术在Python开发中发挥着重要作用。调试器可以设置条件断点,帮助程序员分析所有代码。而分析器可以运行程序,并提供运行时的详细信息,同时也能找出程序中的性...

python中,函数和方法异同点(python方法和函数的区别)

在Python中,函数(Function)...

Python入门基础命令详解(python基础入门教程)

以下是Python基本命令的详解指南,专为初学者设计,涵盖基础语法、常用操作和实用示例:Python基本命令详解:入门必备指南1.Python简介特点:简洁易读、跨平台、丰富的库支持...