溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何解決Mongodb中關(guān)于GUID的顯示問(wèn)題

發(fā)布時(shí)間:2020-07-28 16:01:21 來(lái)源:億速云 閱讀:308 作者:小豬 欄目:MySQL數(shù)據(jù)庫(kù)

這篇文章主要講解了如何解決Mongodb中關(guān)于GUID的顯示問(wèn)題,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。

發(fā)現(xiàn)問(wèn)題

最近將一個(gè)程序的存儲(chǔ)遷移到了Mongodb,發(fā)現(xiàn)了一個(gè)現(xiàn)象,Guid類型寫入后,在程序里面讀取的和用客戶端工具展示的不一樣,一個(gè)簡(jiǎn)單的示例如下:

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

寫入DB后,我們從客戶端工具來(lái)查看它:

如何解決Mongodb中關(guān)于GUID的顯示問(wèn)題

通過(guò)對(duì)比可以發(fā)現(xiàn),展示的值和寫入的形式不一樣,但是讀取到的值卻是沒(méi)有問(wèn)題的。這個(gè)問(wèn)題可以從官方的文檔規(guī)范中找到答案:

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

如何解決Mongodb中關(guān)于GUID的顯示問(wèn)題

Mongodb中是將uuid其作為二進(jìn)制類型存儲(chǔ)的,用一個(gè)subtype來(lái)標(biāo)記其類型為uuid,在對(duì)C#,java,python提供的驅(qū)動(dòng)中,默認(rèn)是將其子類型映射了為3(Legacy UUID),這個(gè)在客戶端工具中也是有所展示的:

如何解決Mongodb中關(guān)于GUID的顯示問(wèn)題

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

如何解決Mongodb中關(guān)于GUID的顯示問(wèn)題   

解決方法

雖然這個(gè)不影響程序的功能,但由于第一眼看到的字符串不是寫入的格式,很多時(shí)候是影響我們調(diào)試程序的。一個(gè)較好的解決方法是默認(rèn)將以標(biāo)準(zhǔn)的UUID格式存儲(chǔ),只需要設(shè)置一個(gè)全局配置即可:

 BsonDefaults.GuidRepresentation = GuidRepresentation.Standard; 

這樣就方便多了:

如何解決Mongodb中關(guān)于GUID的顯示問(wèn)題

看完上述內(nèi)容,是不是對(duì)如何解決Mongodb中關(guān)于GUID的顯示問(wèn)題有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI