


Wie gehe ich mit SQL-NULL-Werten in JSON mithilfe von Go-Typkonvertierungen um?
JSON-Behandlung von SQL-NULL-Werten mit Go-Typkonvertierungen
Während Go-Typen wie Int64 und String keine Nullwerte speichern können, verwenden Sie sql.NullInt64 und sql.NullString ermöglicht diese Funktion. Die Codierung dieser Typen als JSON mithilfe des JSON-Pakets führt jedoch zu einem veränderten Format im Vergleich zu regulären Int64- und String-Typen.
Diese Diskrepanz entsteht, weil sql.Null*-Typen selbst Strukturen sind, was dazu führt eine zusätzliche Verschachtelungsebene in der JSON-Darstellung. Um dies zu umgehen, kann man benutzerdefinierte Typen implementieren, die den Schnittstellen json.Marshaller und json.Unmarshaler entsprechen.
Zum Beispiel kann der Typ JsonNullInt64 definiert werden, indem der Typ sql.NullInt64 eingebettet und eine benutzerdefinierte JSON-Behandlung implementiert wird:
type JsonNullInt64 struct { sql.NullInt64 } func (v JsonNullInt64) MarshalJSON() ([]byte, error) { if v.Valid { return json.Marshal(v.Int64) } else { return json.Marshal(nil) } } func (v *JsonNullInt64) UnmarshalJSON(data []byte) error { // Pointer unmarshalling ensures NULL detection var x *int64 if err := json.Unmarshal(data, &x); err != nil { return err } if x != nil { v.Valid = true v.Int64 = *x } else { v.Valid = false } return nil }
Ersetzen von sql.NullInt64 durch JsonNullInt64 führt zur gewünschten JSON-Kodierung. Weitere Tests finden Sie auf diesem Spielplatz: http://play.golang.org/p/zFESxLcd-c
Das obige ist der detaillierte Inhalt vonWie gehe ich mit SQL-NULL-Werten in JSON mithilfe von Go-Typkonvertierungen um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Das "Strings" -Paket von GO bietet umfangreiche Funktionen, um den Stringbetrieb effizient und einfach zu gestalten. 1) Verwenden Sie Strings.Contains (), um Substrings zu überprüfen. 2) Zeichenfolgen.Split () können verwendet werden, um Daten zu analysieren, sollte jedoch mit Vorsicht verwendet werden, um Leistungsprobleme zu vermeiden. 3) Strings.Join () ist für die Formatierung von Zeichenfolgen geeignet, aber für kleine Datensätze ist Schleifen = effizienter. 4) Für große Saiten ist es effizienter, Saiten mit Streichern zu bauen. Builder.

Go verwendet das "Strings" -Paket für String -Operationen. 1) Verwenden Sie Strings.Join -Funktion, um Strings zu spleißen. 2) Verwenden Sie die Funktionen. Enthält Funktion, um Substrings zu finden. 3) Verwenden Sie die Funktionen für Zeichenfolgen. Diese Funktionen sind effizient und einfach zu bedienen und für verschiedene Aufgaben zur Stringverarbeitung geeignet.

ThebytespackageingoiSessentialFofficyByTeslicemanipulation, AngebotsfunktionenlikeContains, Index, AndreplaceForsearchingandModifyingBinaryData.ItenHancesPerformanceAndCoderDeadability, Makingavitaltoolfor -HandlingBinaryData, NetworkProtocols sowie Filesi

Go verwendet das "Codierung/binäre" Paket für binäre Codierung und Dekodierung. 1) Dieses Paket bietet Binary.Write und Binary.read -Funktionen zum Schreiben und Lesen von Daten. 2) Achten Sie darauf, den richtigen Endian (wie Bigendian oder Littleendian) auszuwählen. 3) Die Datenausrichtung und Fehlerbehandlung sind ebenfalls von entscheidender Bedeutung, um die Richtigkeit und Leistung der Daten zu gewährleisten.

Die "Bytes" PackageingoofferEffictionFunctionsFormAnipulationsByteslices.1) UseBytes.JoinforCatenatingslices, 2) Bytes.BufferforincrementalWriting, 3) Bytes.Indexorbytes.IndexByTeSearching, 4) bytes.readerforreaReasedinforreaReaseding und 5) bytes

Thecoding/binarypackageingoiseffectiveforoptimizingBinaryoperationsduetoitsSupportforendiNnessandefficienceDatahandLing

Das Bytes -Paket von GO wird hauptsächlich zum effizienten Verarbeiten von Bytescheiben verwendet. 1) Verwenden von Bytes.Buffer kann effizient String -Spleißen durchführen, um eine unnötige Speicherzuweisung zu vermeiden. 2) Die Ausgleichsfunktion wird verwendet, um Bytescheiben schnell zu vergleichen. 3) Die Bytes.Index, Bytes.split und Bytes.ReplaceAll -Funktionen können zur Suche und zum Manipulieren von Bytescheiben verwendet werden, aber Leistungsprobleme müssen beachtet werden.

Das Byte -Paket bietet eine Vielzahl von Funktionen, um Bytescheiben effizient zu verarbeiten. 1) Verwenden Sie Bytes.Contains, um die Byte -Sequenz zu überprüfen. 2) Verwenden Sie Bytes.split, um Bytescheiben zu teilen. 3) Ersetzen Sie die Byte -Sequenz -Bytes.replace. 4) Verwenden Sie Bytes.join, um mehrere Byte -Scheiben zu verbinden. 5) Verwenden Sie Bytes.Buffer, um Daten zu erstellen. 6) Kombinierte Bytes.Map für die Fehlerverarbeitung und Datenüberprüfung.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

EditPlus chinesische Crack-Version
Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

Sicherer Prüfungsbrowser
Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

mPDF
mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),

Dreamweaver CS6
Visuelle Webentwicklungstools
