Mongodb中GUID的顯示問題


最近將一個程序的存儲遷移到了Mongodb,發現了一個現象,Guid類型寫入后,在程序里面讀取的和用客戶端工具展示的不一樣,一個簡單的示例如下:

    var doc = new {_id = 1, Value = Guid.Parse("{B63932BB-9688-432B-B3A0-C4AE3FD2696A}") };
    collection.InsertOne(doc.ToBsonDocument());

寫入DB后,我們從客戶端工具來查看它:

    

通過對比可以發現,展示的值和寫入的形式不一樣,但是讀取到的值卻是沒有問題的。這個問題可以從官方的文檔規范中找到答案:

官方文檔: http://bsonspec.org/spec.html

Mongodb中是將uuid其作為二進制類型存儲的,用一個subtype來標記其類型為uuid,在對C#,java,python提供的驅動中,默認是將其子類型映射了為3(Legacy UUID),這個在客戶端工具中也是有所展示的:

    

實際上,大多數客戶端工具也是能支持將Legacy UUID展示成我們寫入時候的那個樣子。

    

    

雖然這個不影響程序的功能,但由於第一眼看到的字符串不是寫入的格式,很多時候是影響我們調試程序的。一個較好的解決方法是默認將以標准的UUID格式存儲,只需要設置一個全局配置即可:

    BsonDefaults.GuidRepresentation = GuidRepresentation.Standard; 

新版本的MongoDB的API為:   

  BsonSerializer.RegisterSerializer(new GuidSerializer(GuidRepresentation.Standard));

這樣就方便多了:

    

參考文章:

MongoDB Best Practices for UUID Data

 


免責聲明!

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



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