Wie interagiere ich mit JSON-Daten mithilfe von SQL in Golang?
在 Golang 中通过 SQL 与 JSON 数据交互共有以下步骤:使用 json.Unmarshal 函数将 JSON 数据解析为 Go 结构体,实现 JSON 到结构体的转换。使用 database/sql 包访问和操作 SQL 数据库,执行诸如插入、查询等操作。结合上述步骤,可以在 Go 中构建基于 SQL 和 JSON 的应用,实现用户注册和登录等功能。
如何在 Golang 中使用 SQL 与 JSON 数据交互
Golang 提供了强大的库和包,使使用 SQL 与 JSON 数据交互变得轻而易举。以下是如何在 Golang 中实现 SQL 与 JSON 交互:
使用 json.Unmarshal
json.Unmarshal 函数可将 JSON 数据解析为 Golang 结构体。例如:
type User struct { ID int64 `json:"id"` Name string `json:"name"` Email string `json:"email"` Created int64 `json:"created"` } var jsonString = `{ "id": 1, "name": "John Doe", "email": "john@example.com", "created": 1587398123 }` var user User err := json.Unmarshal([]byte(jsonString), &user) if err != nil { fmt.Println("Error:", err) }
使用 database/sql
database/sql 包提供了访问和操作 SQL 数据库的功能。示例如下:
import ( "database/sql" "log" ) func main() { db, err := sql.Open("postgres", "user:password@host:port/dbname") if err != nil { log.Fatal(err) } defer db.Close() jsonValue := "{ \"name\": \"Joe\", \"age\": 30 }" // 从 JSON 中创建 SQL struct type User struct { Name string Age int } user := User{Name: "Joe", Age: 30} // 将 SQL struct 转换为 JSON userJSON, err := json.Marshal(user) if err != nil { log.Fatal(err) } // 使用 JSONB 类型插入 JSON 值 _, err = db.Exec("INSERT INTO users (name, age) VALUES ($1, $2)", jsonValue, user.Age) if err != nil { log.Fatal(err) } // 查询 JSON 值 rows, err := db.Query("SELECT * FROM users") if err != nil { log.Fatal(err) } defer rows.Close() for rows.Next() { var name string var age int var jsonString string if err := rows.Scan(&name, &age, &jsonString); err != nil { log.Fatal(err) } println(name, age, jsonString) } }
实战案例:用户注册与登录
我们可以利用 Go 的 SQL 与 JSON 交互能力构建一个简单的用户注册和登录 API:
注册 API
func register(w http.ResponseWriter, r *http.Request) { var user User if err := json.NewDecoder(r.Body).Decode(&user); err != nil { http.Error(w, "Invalid JSON", http.StatusBadRequest) return } // 将 JSON 转换为 SQL struct sqlUser := sqlx.Named("name", user.Name).Named("password", user.Password) // SQL 查询插入 query := `INSERT INTO users (name, password) VALUES (:name, :password)` if _, err := db.NamedExec(query, sqlUser); err != nil { http.Error(w, "Could not register user", http.StatusInternalServerError) return } fmt.Fprintf(w, "User registered successfully") }
登录 API
func login(w http.ResponseWriter, r *http.Request) { var user User if err := json.NewDecoder(r.Body).Decode(&user); err != nil { http.Error(w, "Invalid JSON", http.StatusBadRequest) return } // SQL 查询 query := `SELECT * FROM users WHERE name = $1 AND password = $2` var result User if err := db.Get(&result, query, user.Name, user.Password); err != nil { http.Error(w, "Invalid user credentials", http.StatusUnauthorized) return } // 将 SQL struct 转换为 JWT 令牌 tokenString, err := createJWT(result) if err != nil { http.Error(w, "Could not create JWT", http.StatusInternalServerError) return } fmt.Fprintf(w, "User authenticated. Token: %s", tokenString) }
Das obige ist der detaillierte Inhalt vonWie interagiere ich mit JSON-Daten mithilfe von SQL in Golang?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Das sichere Lesen und Schreiben von Dateien in Go ist von entscheidender Bedeutung. Zu den Richtlinien gehören: Überprüfen von Dateiberechtigungen, Schließen von Dateien mithilfe von Verzögerungen, Validieren von Dateipfaden, Verwenden von Kontext-Timeouts. Das Befolgen dieser Richtlinien gewährleistet die Sicherheit Ihrer Daten und die Robustheit Ihrer Anwendungen.

Der Unterschied zwischen dem GoLang-Framework und dem Go-Framework spiegelt sich in der internen Architektur und den externen Funktionen wider. Das GoLang-Framework basiert auf der Go-Standardbibliothek und erweitert deren Funktionalität, während das Go-Framework aus unabhängigen Bibliotheken besteht, um bestimmte Zwecke zu erreichen. Das GoLang-Framework ist flexibler und das Go-Framework ist einfacher zu verwenden. Das GoLang-Framework hat einen leichten Leistungsvorteil und das Go-Framework ist skalierbarer. Fall: Gin-Gonic (Go-Framework) wird zum Erstellen der REST-API verwendet, während Echo (GoLang-Framework) zum Erstellen von Webanwendungen verwendet wird.

Backend Learning Path: Die Erkundungsreise von Front-End zu Back-End als Back-End-Anfänger, der sich von der Front-End-Entwicklung verwandelt, Sie haben bereits die Grundlage von Nodejs, ...

Die Verwendung vordefinierter Zeitzonen in Go umfasst die folgenden Schritte: Importieren Sie das Paket „time“. Laden Sie eine bestimmte Zeitzone über die LoadLocation-Funktion. Verwenden Sie die geladene Zeitzone für Vorgänge wie das Erstellen von Zeitobjekten, das Analysieren von Zeitzeichenfolgen und das Durchführen von Datums- und Uhrzeitkonvertierungen. Vergleichen Sie Daten mit unterschiedlichen Zeitzonen, um die Anwendung der vordefinierten Zeitzonenfunktion zu veranschaulichen.

Welche Bibliotheken in GO werden von großen Unternehmen oder bekannten Open-Source-Projekten entwickelt? Bei der Programmierung in Go begegnen Entwickler häufig auf einige häufige Bedürfnisse, ...

Go Language funktioniert gut beim Aufbau effizienter und skalierbarer Systeme. Zu den Vorteilen gehören: 1. hohe Leistung: Kompiliert in den Maschinencode, schnelle Laufgeschwindigkeit; 2. gleichzeitige Programmierung: Vereinfachen Sie Multitasking durch Goroutinen und Kanäle; 3. Einfachheit: präzise Syntax, Reduzierung der Lern- und Wartungskosten; 4. plattform: Unterstützt die plattformübergreifende Kompilierung, einfache Bereitstellung.

Automatische Löschung von Golang Generic -Funktionstypeinschränkungen in VSCODE -Benutzern kann auf ein seltsames Problem beim Schreiben von Golang -Code mit VSCODE stoßen. Wann...

Effizient behandeln Probleme mit der Parallelitätssicherheit beim Schreiben von Multi-Process-Protokoll. Mehrere Prozesse schreiben gleichzeitig die gleiche Protokolldatei. Wie kann die Parallelität sicher und effizient sichergestellt werden? Das ist ein ...
