专栏首页AustinDatabasesPostgreSQL 的JSON 处理甩“你”几条街

PostgreSQL 的JSON 处理甩“你”几条街

首先这里的你绝对不是MONGODB ,至于是谁,你是谁,那的先了解POSTGRESQL 处理 JSON 的方式后,才能确定那个你是谁。

首先POSTGRESQL 支持两种JSON格式,JSON and JSONB ,在PG 9.X 版本对JSON的支持就已经出具规模了(MONGODB 中的支持BSON格式),拿在postgresql 中大概率的你是要使用JSONB 这样的格式,这样的格式有以下一些好处

1 处理的速度快

2 可以添加索引

当然也有一些东西是有限制的,这里先不表,另外学习的过程,我发现一个点,就是如果你能在学习的过程中,先得到一点甜头,则你后续的学习就会有兴趣,并且很可能越学越快

所以下面我们先做一点实践,增加兴趣

我们建立一个表,如果按照MONGODB 来说,应该叫collection, 然后我们插入一条 document ,格式是jsonb ,但如果你用MONGODB 的方式来理解,你可以找到一点不一样的地方

可以看到,其实要展示数据在POSTGRESQL 中也并不是难事

然后我们创建一个索引,熟悉PG的人都知道他模糊查询的厉害,下面的索引的建立也颇有那几分味道。

explain analyze SELECT * FROM json_test WHERE info @> '{"name": "Calor"}';

查询中也有一些 JSONB 特殊的查询的方式,但这样的查询方式比初次使用MONGODB 的查询语句对熟悉SQL 的人要亲切的多。

到这里我们可以小结一下,PostgreSQL 里面的JSON 可以使用JSONB 的方式来进行存储,并且大部分时间创建一个GIN 的索引就可以满足大部分查询,如果使用过MONGODB 的,可以知道MONGODB 本身存储是B+树来存储索引的,特定的查询也要配合特定建立的索引,这点上就.......

下面我们继续做测试,看看是不是POSTGRESQL 可以一个索引就将所有的查询都HOLD 住。

下面我们创建,一个新的collection

create table test_json_2 (info jsonb);

插入数据

insert into test_json_2 select ('{"name": "nn-' || round(random()*20000000) || '", "ajon": "address", "tags": ["system", "database", "langrage"]}')::jsonb from (select * from generate_series(1,100000)) as temp;

一个10万行的collection就生成了,照方抓药,创建索引后,直接查询,结果很明显是可以走索引的。

并且网上提及的某些不能走索引的情况,在PG11 这个版本也是可以开始走索引了。

当然如果你统计的数据是全表,或大部分数据,则还是要走全表扫描的

这里大致的看了一下POSTGRESQL 对JOSN 的支持,相对于某些数据库还是友好的,并且符合人类快速理解和上手的方式。

当然在面对专业文档数据库MONGODB 的强大的处理能力下,没有其他的数据库可以抗衡,因为那个是他的 饭碗,如果不是很复杂(就是那种嵌套,嵌套,嵌套,还有数组的让人头要炸开的那种)的JSON 或者你没有专业的MONGODB 的支持,想使用JSON 或文档的方式在数据库里面不想失望的使用,POSTGRESQL 是一个选择,不错的。

说到这里,那个题目中的“你”到底应该颁给谁?心里早就有答案了吧

本文分享自微信公众号 - AustinDatabases(AustinDatabases),作者:carol11

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-03-25

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • MYSQL 中的查询技巧 与 MYSQL 8 并行查询

    最近公司的系统一点点的开始了拆分,从ORACLE 转移到 MYSQL 中,部分程序员的想法在使用MYSQL中还是没有转变过来,直接将ORALCE中的查询语句直接...

    AustinDatabases
  • MYSQL JSON 初步体验

    Json 作为程序员最受欢迎的数据格式,使用的越来越广泛了,如果你目前使用的数据库不支持JSON的格式,那显然是满足不了程序员以及 程序微服化的需求以及消息传递...

    AustinDatabases
  • MONGODB "表也用设计" 麻烦您 “走点心”

    起初我单纯的认为是,分析人员不会语法导致的,但是后面我发现问题没有那么“简单”。这里以 鹏元的某些反馈的征信数据为例,这样的MONGODB 的“表”设计的确是不...

    AustinDatabases
  • C# 多线程九之Timer类

    相信写过定时任务的小伙伴都知道这个类,非常的轻量级,而且FCL中大量的类使用了这个方法,比如CancellationTokenSource的CancelAfte...

    郑小超.
  • Java虚拟机内存溢出原因分析以及解决方案

    在Java虚拟机规范的描述之中,除了程序计数器外,虚拟机内存的其他几个运行时区域都有可能发生内存溢出OutOfMemoryError(OOM)异常的可能。

    爱明依
  • MySQL 学习笔记【索引篇】

    索引是一种数据结构。官方描述为:索引(Index)是帮助MySQL高效获取数据的数据结构。因此我们针对索引的使用和优化,本质上也是基于一种特殊的数据结构进行的优...

    秦穆之
  • 【电工与电子技术A】一:电路及其基本物理量

    一类电路用以实现电能的生产,传输,转换和分配,如店里供电设备与各用电设备组成的电力系统。

    周旋
  • 区块链一键登录:MetaMask教程(One-click Login with Blockchain: A MetaMask Tutorial)

    在线用户对传统电子邮件/密码注册流程的抵抗力日益增强。通过Facebook,Google或GitHub的一键式社交登录功能被证明是更理想的选择。然而,它存在一种...

    汐楓
  • 第二十九课 如何实现MetaMask签名授权后DAPP一键登录功能?

    网站太多,各种用户名/密码实在记不住。所以我们逐渐接受了BAT账号的授权登录功能。在以太坊DAPP应用中,也可以使用MetaMask实现授权后一键登录功能。Me...

    辉哥
  • Python 中最简最好的设计模式

    Python 诞生于1991年,而下一场技术革命已然开始,AI 时代已然成风。在 AI 领域中已经被广泛使用的 Python 必将成为下一个时代的第一开发语言!

    py3study

扫码关注云+社区

领取腾讯云代金券