Jump to content

BSON: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Eliovir (talk | contribs)
m {{Data Exchange}}
→‎Data types and syntax: "Binary Integer Decimal (BID): MongoDB uses this binary encoding for the coefficient as specified in IEEE 754-2008. The byte order is little-endian, like the rest of the BSON types."
Line 12: Line 12:


==Data types and syntax==
==Data types and syntax==
BSON documents (objects) consist of an ordered list of ''elements''. Each element consists of a field name, a type, and a value. Field names are strings. Types include:
BSON documents (objects) consist of an ordered list of ''elements''.<ref>bsonspec.org/spec.html</ref>

www.informit.com/articles/article.aspx?p=2247310&seqNum=4 api.mongodb.com/python/current/api/bson/regex.html MongoDB uses Perl compatible regular expressions (i.e. “PCRE” ) version 8.41 with UTF-8 support

Each element consists of a field name, a type, and a value. Field names are strings. Types include:


* string
* string
* integer (32- or 64-bit)
* integer (32- or 64-bit)
* double (64-bit [[IEEE 754]] floating point number)
* double (64-bit [[IEEE 754]] floating point number)
* decimal128 (128-bit [[IEEE 754]] floating point number), suitable as a carrier for arbitrary precision numerics
* decimal128 (128-bit [[IEEE 754-2008]] floating point number; Binary Integer Decimal (BID) variant), suitable as a carrier for arbitrary precision numerics with 34 decimal digits of precision, a max value of approximately 10<sup>6145</sup>
* date (integer number of milliseconds since the [[Unix epoch]])
* date (integer number of milliseconds since the [[Unix epoch]])
* byte array (binary data)
* byte array (binary data)
Line 26: Line 30:
* JavaScript code
* JavaScript code
* MD5 binary data
* MD5 binary data
* Regular expression (Perl compatible regular expressions ("[[PCRE]]") version 8.41 with UTF-8 support, e.g. not fully Python compatible)<ref>api.mongodb.com/python/current/api/bson/regex.html</ref>
* Regular expression
* MD5 binary data


BSON types are nominally a superset of [[JSON]] types (JSON does not have a date or a byte array type, for example<ref name="json">[http://www.json.org/ JSON Specification]</ref>), with one exception of not having a universal "number" type as JSON does.
BSON types are nominally a superset of [[JSON]] types (JSON does not have a date or a byte array type, for example<ref name="json">[http://www.json.org/ JSON Specification]</ref>), with one exception of not having a universal "number" type as JSON does.

Revision as of 11:20, 17 January 2018

BSON
Filename extension
.bson
Internet media type
none[1]
Type of formatData interchange
Extended fromJSON
Standardno RFC yet
Websitebsonspec.org

BSON /ˈbsən/ is a computer data interchange format used mainly as a data storage and network transfer format in the MongoDB database. It is a binary form for representing simple data structures, associative arrays (called objects or documents in MongoDB), and various data types of specific interest to MongoDB. The name "BSON" is based on the term JSON and stands for "Binary JSON".[2]

Data types and syntax

BSON documents (objects) consist of an ordered list of elements.[3]

www.informit.com/articles/article.aspx?p=2247310&seqNum=4 api.mongodb.com/python/current/api/bson/regex.html MongoDB uses Perl compatible regular expressions (i.e. “PCRE” ) version 8.41 with UTF-8 support

Each element consists of a field name, a type, and a value. Field names are strings. Types include:

  • string
  • integer (32- or 64-bit)
  • double (64-bit IEEE 754 floating point number)
  • decimal128 (128-bit IEEE 754-2008 floating point number; Binary Integer Decimal (BID) variant), suitable as a carrier for arbitrary precision numerics with 34 decimal digits of precision, a max value of approximately 106145
  • date (integer number of milliseconds since the Unix epoch)
  • byte array (binary data)
  • boolean (true and false)
  • null
  • BSON object
  • BSON array
  • JavaScript code
  • MD5 binary data
  • Regular expression (Perl compatible regular expressions ("PCRE") version 8.41 with UTF-8 support, e.g. not fully Python compatible)[4]
  • MD5 binary data

BSON types are nominally a superset of JSON types (JSON does not have a date or a byte array type, for example[5]), with one exception of not having a universal "number" type as JSON does.

Efficiency

Compared to JSON, BSON is designed to be efficient both in storage space and scan-speed. Large elements in a BSON document are prefixed with a length field to facilitate scanning. In some cases, BSON will use more space than JSON due to the length prefixes and explicit array indices.[2]

Example

A document such as {"hello":"world"} will be stored as:

Bson:
  \x16\x00\x00\x00               // total document size
  \x02                           // 0x02 = type String
  hello\x00                      // field name
  \x06\x00\x00\x00world\x00      // field value (size of value, value, null terminator)
  \x00                           // 0x00 = type EOO ('end of object')

See also

References

  1. ^ MIME Media Types - The Internet Assigned Numbers Authority
  2. ^ a b BSON Specification
  3. ^ bsonspec.org/spec.html
  4. ^ api.mongodb.com/python/current/api/bson/regex.html
  5. ^ JSON Specification

External links