Detaillierte Analyse von GUID-Anzeigeproblemen in Mongodb

Detaillierte Analyse von GUID-Anzeigeproblemen in Mongodb

Finden Sie das Problem

Ich habe kürzlich den Speicher eines Programms nach Mongodb migriert und dabei ein Phänomen entdeckt: Nachdem der Guid-Typ geschrieben wurde, unterscheiden sich die im Programm gelesenen Daten von den vom Client-Tool angezeigten Daten. Ein einfaches Beispiel dafür ist wie folgt:

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

Nachdem wir in die Datenbank geschrieben haben, zeigen wir sie vom Client-Tool aus an:

Durch einen Vergleich kann festgestellt werden, dass der angezeigte Wert von der geschriebenen Form abweicht, der abgelesene Wert jedoch korrekt ist. Die Antwort auf diese Frage finden Sie in der offiziellen Dokumentationsspezifikation:

Offizielle Dokumentation: http://bsonspec.org/spec.html

Mongodb speichert UUID als Binärtyp und verwendet einen Subtyp, um seinen Typ als UUID zu kennzeichnen. In den für C#, Java und Python bereitgestellten Treibern wird der Subtyp standardmäßig auf 3 (Legacy UUID) abgebildet, was auch im Clienttool angezeigt wird:

Tatsächlich unterstützen die meisten Client-Tools auch die Anzeige der Legacy-UUID so, wie wir sie geschrieben haben.

Problemumgehung

Obwohl dies die Funktionalität des Programms nicht beeinträchtigt, beeinträchtigt es häufig unser Debugging des Programms, da die Zeichenfolge, die wir auf den ersten Blick sehen, nicht in dem Format vorliegt, in dem sie geschrieben wurde. Eine bessere Lösung ist, standardmäßig im Standard-UUID-Format zu speichern. Sie müssen nur eine globale Konfiguration festlegen:

 BsonDefaults.GuidRepresentation = GuidRepresentation.Standard;

Das ist viel bequemer:

Referenzartikel:

MongoDB Best Practices für UUID-Daten

Zusammenfassen

Oben finden Sie ausführliche Informationen zum Anzeigeproblem von GUID in Mongodb. Weitere Informationen zum Anzeigeproblem von GUID in Mongodb finden Sie in den anderen verwandten Artikeln auf 123WORDPRESS.COM!

<<:  Beispiele für die korrekte Verwendung von Karten in WeChat-Miniprogrammen

>>:  Zusammenfassung von 9 hervorragenden Codevergleichstools, die unter Linux empfohlen werden

Artikel empfehlen

Detaillierte Erklärung der Filter und Anweisungen in Vue

Inhaltsverzeichnis benutzerdefinierte Vue-Direkti...

Detaillierte Erläuterung gängiger Methoden von JavaScript String

Inhaltsverzeichnis 1. charAt Grammatik Parameter ...

Detaillierte Erklärung der Webseiten-Screenshot-Funktion in Vue

Seit Kurzem besteht im Projekt die Anforderung, B...

Die entsprechenden Attribute und Verwendung von XHTML-Tags in CSS

Als ich anfing, Webseiten mit XHTML CSS zu entwer...

Kann Docker das nächste „Linux“ werden?

Das Linux-Betriebssystem hat das Rechenzentrum in...

Sprechen Sie über wichtige Unterverzeichnisprobleme im Linux-System

/etc/fstab Partitionen/Festplatten automatisch mo...

Ausführliche Erklärung des Sperrmechanismus in MySQL InnoDB

Vorne geschrieben Eine Datenbank ist im Wesentlic...

Analyse der Implementierungsschritte für die Docker-Containerverbindung

Im Allgemeinen verwenden wir nach dem Start des C...

Zusammenfassung der vier Klick-Antwortmethoden von Button

Button wird ziemlich oft verwendet. Hier habe ich...

js zur Realisierung einer einfachen Warenkorbfunktion

In diesem Artikelbeispiel wird der spezifische Co...

So installieren Sie Elasticsearch und Kibana in Docker

Elasticsearch erfreut sich derzeit großer Beliebt...