<?php /* mongodb_數據類型(null/字符串/數字/日期/內嵌文檔/數組等)(轉並學習) MongoDB的文檔類似於JSON,JSON只是一種簡單的表示數據的方式,只包含了6種數據類型(null、布爾、數字、字符串、數組及對象). JSON的數據類型的局限性: 1.無日期類型,對日期型的處理較為繁瑣 2.無法區分浮點數和整數、32位和64位 3.其他類型表示局限 如函數、正則式等 Mongodb使用BSON(Binary JSON)來組織數據,BSON還提供日期、32位數字、64位數字等類型。下面為在mongodb shell中這些類型在文檔中是如何表示: 1、null 用於表示空值或者不存在的字段。 {"name":null} 2.布爾 布爾類型、即true和false {"flag":true}/{"flag":false} 3.數字 mongodb中分32位整數、64位整數、64位浮點數 >javascript只支持64位浮點數,shell中對32位的整數會進行自動的轉換: 默認情況下,shell中的數字被mongdb當做是雙精度。若從數據庫中獲取一個32位整數,修改了文檔后在將文檔保存到數據庫的時候,這個整數已被轉換成了浮點數(整數不變也會轉換)。 >shell中會用內嵌文檔的方式顯示64位整數: 數字智能表示為雙精度數(64位浮點數)的另一個問題是,有些64位的整數並不能精確的表示64位浮點數。因此要是存入了一個64位整數然后在shell中查看,它顯示一個內嵌的文檔,表示可能不准確。 如: 插入文檔{"name":"apple","num":5},其中"num"設置為64位整數5. 查看如下: { "_id" : ObjectId("5000f7af32e3988ad237a202"), "name" : "apple", "num" : {"floatApprox" : 5} } =================================== =================================== 這里並沒有發現這種情況,可能是我的系統是32位的吧 =================================== =================================== 插入文檔{"name":"orange","num":9223372036854775807} 查看如下: { "_id" : ObjectId("5000f7af32e3988ad237a203"), "name" : "apple", "num" : {"floatApprox" : 9223372036854776000 ,"top" : 2147483647 , "bottom" : 4294967295} } =================================== =================================== 這里同樣輸入了 9223372036854776000也沒有發現輸出的情況 =================================== =================================== {"name":"apple","num":5} {"name":"orange","num":9223372036854775807} {"name":"peach","num":922337203685477580743254354565678678998935345} >db.a.find() { "_id" : ObjectId("5000f7af32e3988ad237a204"), "name" : "apple", "num" : 5 } { "_id" : ObjectId("5000f87432e3988ad237a205"), "name" : "orange", "num" : 9223372036854776000 } { "_id" : ObjectId("5000fbd232e3988ad237a206"), "name" : "peach", "num" : 9.223372036854776e+44 } =================================== =================================== 我這里情況基本一樣,存入過大數量也會變成浮點數 64位浮點數: {"num":3.14}/{"num":3} =================================== =================================== 存是可以,但后面的精度如果過高的話,會有丟失情況且 4.字符串 UTF-8字符串都可以表示為字符串類型的數據 {"name":"orange"} 5.符號 shell中不支持,並將數據庫里的符號類型都轉換成字符串 6.對象id是文檔的12字節的唯一ID {"x":Object()} Mongodb中存儲的(同一個集合內)文檔必須有,只有唯一的“_id”鍵。值可為任意類型,必須保證其唯一性,默認為ObjectId對象。至於mongodb為什么用ObjectId對象,以及它有什么好處等請翻閱相關資料。 下面是ObjectId的構成: ObjectId使用12字節的存儲空間,每個字節兩位十六進制數字,是一個24位的字符串。12字節按照如下方式生成: 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 時間戳 | 機器碼 | PID | 計數器 ----------------------------------------------- >時間戳:從標准的紀元開始的時間戳,單位為秒。 >機器碼:所在主機的唯一標示符,通常為機器主機名的散列值。 >PID:產生ObjectId的進程標示符。 >計數器:自動增加計數器,同一秒最多允許每個進程擁有256的3次方(16777216)個不同的ObjectId。 文檔的"_id"鍵: 1.插入文檔的時候,沒有該鍵,系統自動創建一個。 2.mongodb服務器可自動創建,通常在客戶端由驅動程序完成: >減少數據庫擴展的負擔 >驅動程序提供豐富的API,可返回ObjectId,也可插入文檔;若有服務器生成的話,驅動程序需單獨的查詢來確定插入的文檔中的"_id"值。 7.日期型 存儲的是從標准紀元開始的毫秒數,不存儲時區。 {"name":"xx","date":new Date()} 本機查看:{ "_id" : ObjectId("5001047632e3988ad237a206"), "name" : "xx", "date" : ISODate("2012-07-14T05:32:38.189Z") } 8.正則式 文檔中可以包含正則表達式,采用javascript的正則表達式語法 {"regex":/[0-9]/g} 9.代碼或者函數 javascript代碼(mongodb中值直接保存到數據庫,不對值進行執行,因此不存在安全問題) {"setName":function(){var name="jk";alert(name)}} =================================== =================================== 這個function(){val name="jk"; alert(name)} 並沒有插入成功到文檔中,提示錯誤 10.二進制數 可以由任意字節的串組成。shell中無法使用。 11.最大值 BSON包括一個特殊類型,表示可能的最大值。shell沒有這個類型。 12.最小值 BSON包括一個特殊類型,表示可能的最小值。shell沒有這個類型。 13.未定義(undefined) 文檔中也可以使用未定義類型 {"name":undefined} =================================== =================================== undefined存入數據庫后,值變為了null 14.數組 值的集合或者列表可以表示成數組 {"name":["s","d","f"]} 15.內嵌文檔 文檔可以包含文檔,作為值嵌入到父文檔中 {"sch" : "s" "catl" : { "c1" : {"cls1" : "cs1","cls2" : "cs2","cls3" : "cs3"} "c2" : {"cls1" : "cs1","cls2" : "cs2","cls3" : "cs3"} "c3" : {"cls1" : "cs1","cls2" : "cs2","cls3" : "cs3"} } } 從面向對象的角度來理解文檔,文檔就是個對象,文檔里面的key/value就是屬性和屬性值。 */ ?>