發(fā)現(xiàn)問題
最近將一個程序的存儲遷移到了Mongodb,發(fā)現(xiàn)了一個現(xiàn)象,Guid類型寫入后,在程序里面讀取的和用客戶端工具展示的不一樣,一個簡單的示例如下:
var doc = new {_id = 1, Value = Guid.Parse("{B63932BB-9688-432B-B3A0-C4AE3FD2696A}") };
collection.InsertOne(doc.ToBsonDocument());
寫入DB后,我們從客戶端工具來查看它:
通過對比可以發(fā)現(xiàn),展示的值和寫入的形式不一樣,但是讀取到的值卻是沒有問題的。這個問題可以從官方的文檔規(guī)范中找到答案:
官方文檔: http://bsonspec.org/spec.html
Mongodb中是將uuid其作為二進制類型存儲的,用一個subtype來標記其類型為uuid,在對C#,java,python提供的驅(qū)動中,默認是將其子類型映射了為3(Legacy UUID),這個在客戶端工具中也是有所展示的:
實際上,大多數(shù)客戶端工具也是能支持將Legacy UUID展示成我們寫入時候的那個樣子。
解決方法
雖然這個不影響程序的功能,但由于第一眼看到的字符串不是寫入的格式,很多時候是影響我們調(diào)試程序的。一個較好的解決方法是默認將以標準的UUID格式存儲,只需要設置一個全局配置即可:
BsonDefaults.GuidRepresentation = GuidRepresentation.Standard;
這樣就方便多了:
參考文章:
MongoDB Best Practices for UUID Data
總結(jié)
以上就是Mongodb中關于GUID的顯示問題的詳細內(nèi)容,更多關于Mongodb中GUID顯示問題的資料請關注腳本之家其它相關文章!