MongoDB的數據類型


一.MongoDB 之 豐富多彩的數據類型世界

首先我們要先了解一下MongoDB中有什么樣的數據類型:

Object  ID :Documents 自生成的 _id

String: 字符串,必須是utf-8

Boolean:布爾值,true 或者false (這里有坑哦~在我們大Python中 True False 首字母大寫)

Integer:整數 (Int32 Int64 你們就知道有個Int就行了,一般我們用Int32)

Double:浮點數 (沒有float類型,所有小數都是Double)

Arrays:數組或者列表,多個值存儲到一個鍵 (list哦,大Python中的List哦)

Object:如果你學過Python的話,那么這個概念特別好理解,就是Python中的字典,這個數據類型就是字典

Null:空數據類型 , 一個特殊的概念,None Null

Timestamp:時間戳

Date:存儲當前日期或時間unix時間格式 (我們一般不用這個Date類型,時間戳可以秒殺一切時間類型)

看着挺多的,但是真要是用的話,沒那么復雜,很簡單的哦

 

二.MongoDB 之 剖析MongoDB的數據類型

那么我們根據以上所說的數據類型(撿重點說,別整沒用的)展開說明:

1.Object ID :

"_id" : ObjectId("5b151f8536409809ab2e6b26")

#"5b151f85" 代指的是時間戳,這條數據的產生時間
#"364098" 代指某台機器的機器碼,存儲這條數據時的機器編號
#"09ab" 代指進程ID,多進程存儲數據的時候,非常有用的
#"2e6b26" 代指計數器,這里要注意的是,計數器的數字可能會出現重復,不是唯一的
#以上四種標識符拼湊成世界上唯一的ObjectID
#只要是支持MongoDB的語言,都會有一個或多個方法,對ObjectID進行轉換
#可以得到以上四種信息

#注意:這個類型是不可以被JSON序列化的

這是MongoDB生成的類似關系型DB表主鍵的唯一key,具體由24個字節組成:

0-8字節是時間戳,

9-14字節的機器標識符,表示MongoDB實例所在機器的不同;

15-18字節的進程id,表示相同機器的不同MongoDB進程。

19-24字節是計數器

 

2.String :

UTF-8字符串,記住是UTF-8字符串

 

3.Boolean :

true or false 這里首字母是小寫的

 

4.Integer :

整數 (Int32 Int64 你們就知道有個Int就行了,一般我們用Int32)

 

5.Double :

浮點數 (MongoDB中沒有float類型,所有小數都是Double)

 

6.Arrays :

{
    "_id" : ObjectId("5b163830993ddc4cd4918ead"),
    "name" : "LuffyCity",
    "teacher" : [
        "DragonFire",
        "WuSir2B",
        "Alex AGod"
    ]
}

數組或者列表,多個值存儲到一個鍵 (list哦,大Python中的List哦

 

7.Object :

{
    "_id" : ObjectId("5b163915993ddc4cd4918eaf"),
    "name" : "LuffyCity",
    "course" : {
        "name" : "Python",
        "price" : 19800
    }
}

如果你學過Python的話,那么這個概念特別好理解,就是Python中的字典,這個數據類型就是字典

 

8.Null :

{
    "_id" : ObjectId("5b163a0e993ddc4cd4918eb0"),
    "name" : "LuffyCity",
    "course" : null
}

空數據類型 , 一個特殊的概念,None Null

 

9.Timestamp :時間戳

{
    "_id" : ObjectId("5b163bbf993ddc4cd4918eb3"),
    "name" : "LuffyCity",
    "date" : 1528183743111
}

 

10.Date :

 

{
    "_id" : ObjectId("5b163ba1993ddc4cd4918eb2"),
    "name" : "LuffyCity",
    "date" : ISODate("2018-06-05T15:28:33.705+08:00")
}

 存儲當前日期或時間格式 (我們一般很少使用這個Date類型,因為時間戳可以秒殺一切時間類型)

 

數據類型就介紹到這里了,接下來我們就要學習一下在數據進行增刪改查時,數據類型的特殊用法


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM