本文由码农网 – 小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划

长话短说:如果你想知道JSON——它是什么,如何使用它以及它和BSON哪个更好,那么你来对地方了。在本文中,我们将探讨这些缩写字母代表什么意思,以及这些格式在编程和数据库世界中有什么作用。

什么是JSON?

JSON代表JavaScript Object Notation。基本上说来,它使用从JavaScript衍生的语法,用一种人类和机器都可读的方式来表示数据。例如,JSON网站上使用的一个例子描述了JavaScript Object Notation中的glossary,如下所示:

如何使用JSON

正如你所看到的,我们创建了层次结构,在一系列花括号内({})封装各个层次。在每个层次中,有名称/值对,如“title”:“example glossary”。用和JavaScript对象相同的方式工作,通过启动新的花括号,对的值部分可以打开但却会是另一个层次。这创造了一种良好的数据布局,不但信息可以被机器轻易扫描,而且人类搜索所需要的内容也方便。

这种标记方法允许表示许多数据类型——数字,字符串和布尔值,哈希(用{}封装)和数组(用[]封装)。

一旦数据用这种标记方法表示的话,那么JSON解析器可以用于几乎任何编程语言,将这种标记方法转变为本地数据类型,从而允许程序员使用语言的自然语法访问数据。由于这种标记方法是如此的普遍,因此大多数程序员对存储和检索这种数据类型有着大量丰富的经验。

如何在数据库中使用它?

文档数据库通常用JSON格式或基于这种格式来存储数据。不同于关系数据库使用表格和行,文档数据库会通过使用JSON格式来存储和查询信息。

这些数据库把每组JSON数据作为一个文件。由于结构是层次化的,因此每个文档都可以有关于任何键的子文档。这种设置使得它很容易让熟悉语言的程序员在数据库中存储和查询数据。

什么是BSON?

BSON即Binary JSON。这种格式专门用于MongoDB的文档数据库。其背后的理念是提供JSON格式的功能,同时也能够用自带二进制格式的速度使用该格式。

JSON vs. BSON

JSON仅代表一种数据结构,而MongoDB可以使用BSON在任何层次的基础上构建键数据库索引,从而帮助提高这个领域的速度。MongoDB也提供了一种称为GridFS的规范,可以结合BSON存储数据,同时不受BSON的16MB文件大小的限制。这在存储大文件时真的很有用,因为它会把大文件划分成“块”,以便于在数据库中的存储能够正常工作。

在大多数情况下,JSON和BSON非常相似,但BSON可以提供额外的速度冲击。当然,两者都是应用程序存储和检索数据非常方便的方法。

 

译文链接:http://www.codeceo.com/article/json-vs-bson.html
英文原文:What is JSON? How Do I Use It? Does It Beat BSON?
翻译作者:码农网 – 小峰
转载必须在正文中标注并保留原文链接、译文链接和译者等信息。]

什么是JSON?如何使用?它比BSON更好吗?的更多相关文章

  1. Python3 shevel模块,更高级的json序列化数据类型模块(比pickle更高级)

    直接将数据类型以字典的格式 存到文件中去. 直接.get读取出来,

  2. 从json到python解析python,从bson到monogdb

    1.JSON JSON是JavaScript Object Notation的缩写,中文译为JavaScript对象表示法.用来作为数据交换的文本格式,作用类似于XML,而2001年Douglas C ...

  3. BSON数据格式

    BSON https://baike.baidu.com/item/BSON 概念 编辑 BSON()是一种类json的一种二进制形式的存储格式,简称Binary JSON,它和JSON一样,支持内嵌 ...

  4. MongoDB 将Json数据直接写入MongoDB的方法

    Json转Bson MongoDB中是以Bson数据格式进行存储的,Json字符串没有办法直接写入MongoDB 可以将Json字符串转换成DBObject或者Document,然后写入MongoDB ...

  5. 10.MongoDB:将Json数据直接写入MongoDB的方法

    Json转Bson MongoDB中是以Bson数据格式进行存储的,Json字符串没有办法直接写入MongoDB 可以将Json字符串转换成DBObject或者Document,然后写入MongoDB ...

  6. 【转】BSON数据格式

    原文:https://www.e-learn.cn/content/qita/1999197 ----------------------------------------------------- ...

  7. 初学者看过来之JSON入门

    1. 什么是JSON JSON---Javascript Object Notation,前两个单词大家应该都认识,最后一个notation,是"记号.标记法"的意思,连在一起,便 ...

  8. SQL Server2016 原生支持JSON

    SQL Server2016 原生支持JSON SQL Server 2005 开始支持 XML 数据类型,提供原生的 XML数据类型.XML 索引以及各种管理 XML 或输出 XML 格式的函数. ...

  9. JSON解析和XML解析对比

    JSON解析和XML解析是较为普遍的两种解析方式,其中JSON解析的市场分额更大.本文系统的分析两种解析方式的区别,为更好地处理数据作准备.由于目前阶段主要是做移动开发,所以本文所描述的JSON解析和 ...

随机推荐

  1. 使用Memcached、Spring AOP构建数据库前端缓存框架

    数据库访问可能是很多网站的瓶颈.动不动就连接池耗尽.内存溢出等.前面已经讲到如果我们的网站是一个分布式的大型站点,那么使用 memcached实现数据库的前端缓存是个很不错的选择:但如果网站本身足够小 ...

  2. EWS小记

    前段时间和同事完成了一个Exchange 2010 OWA的改造版,他狠狠的把网易邮箱抄了一把,而我则狠狠的被EWS坑了一把.今天打开项目粗略看了一下,发现很多东西都有点记不起来了,思细极恐,决定还是 ...

  3. BZOJ 3996 [TJOI 2015] 线性代数 解题报告

    首先,我们可以得到: $$D = \sum_{i=1}^{n}\sum_{j=1}^{n}a_i\times a_j\times b_{i,j} - \sum_{i=1}^{n}a_i\times c ...

  4. Linux 系统挂载数据盘

    适用系统:Linux(Redhat , CentOS,Debian,Ubuntu) *  Linux的云服务器数据盘未做分区和格式化,可以根据以下步骤进行分区以及格式化操作. 下面的操作将会把数据盘划 ...

  5. python:UnicodeDecodeError: ‘ascii’ codec can’t decode byte 0xef in position xxx: ordinal not in range(128)

    执行sql_cmd = "select * from item_base where item_id in " + item_ids_str时报错 solve: import sy ...

  6. JDBC MySQL字段类型为datetime的数据取出(util.Date)

    使用ResultSet的getTimestamp方法获取java.util.Date型数据 java.util.Date time = rs.getTimestamp("time" ...

  7. EasyUI 关于IE使用window组件上传文件

    有时候IE会对使用window组件上传文件(第二次)不生效,解决方案是: 将该window每次打开的时候,使用: $('#adUploadWindow').window('refresh', 'pan ...

  8. php PDO连接mysql以及字符乱码处理

    <?php //mysql 的 PDO $dsn = "mysql:dbname=cqkx;host:localhost"; $username = "root&q ...

  9. [codility]Prefix-set

    这题很简单,一开始用了set.但后来一想这样其实是n*logn的,而且没有利用所有的数都在0..N-1之间.那么可以直接用vector当hashset. // you can also use inc ...

  10. Android 用Intent和Bundle传递参数

    传递方: //点击btn_sub传递 fieldHeight.getText()和 fieldWeight.getText() private void setListeners()    {    ...