Golang でデータベースから JSON データを取得するにはどうすればよいですか?
Golang でデータベースから JSON データを取得するには、sql.RawBytes 型を使用して JSON データを保存し、クエリを実行してデータを sql.RawBytes 変数にスキャンし、逆シリアル化します。 JSON データ。
Golang でデータベースから JSON データを取得する方法
Golang では、sql.RawBytes 型を使用して JSON データを保存および取得できます。このアプローチにより、JSON データをバイナリ データとしてデータベースに保存し、取得時に JSON オブジェクトに逆シリアル化することができます。
Golang でデータベースから JSON データを取得する手順は次のとおりです:
1. 必要なライブラリをインストールします
import ( "database/sql" _ "github.com/go-sql-driver/mysql" // 数据库驱动程序(根据需要更改) "encoding/json" )
2. クエリを実行します
データベースから JSON データを取得するには、sql.RawBytes
タイプを使用してください。 db, err := sql.Open("mysql", "user:password@tcp(host:port)/database")
if err != nil {
// 处理错误
}
sql.RawBytes
类型。
rows, err := db.Query("SELECT json_column FROM table_name") if err != nil { // 处理错误 }
4. 扫描行
对于查询的每一行,使用 Scan
方法将 json_column
列扫描到 sql.RawBytes
类型的变量中。
var jsonBytes []byte err = rows.Scan(&jsonBytes) if err != nil { // 处理错误 }
5. 反序列化 JSON 数据
要将二进制 JSON 数据反序列化为 JSON 对象,请使用 json.Unmarshal
函数。
var jsonObject map[string]interface{} err = json.Unmarshal(jsonBytes, &jsonObject) if err != nil { // 处理错误 }
实战案例
假设您有一个名为 users
的表,它有一个名为 json_data
的 JSON
列。要从 users
表中检索 json_data
列:
rows, err := db.Query("SELECT json_data FROM users") if err != nil { // 处理错误 } for rows.Next() { var jsonBytes []byte err = rows.Scan(&jsonBytes) if err != nil { // 处理错误 } var jsonObject map[string]interface{} err = json.Unmarshal(jsonBytes, &jsonObject) if err != nil { // 处理错误 } fmt.Println(jsonObject) }
以上代码将遍历 users
表中的每一行,将 json_data
Scan
メソッドを使用して json_column
列を sql.RawBytes 変数を入力します。 🎜rrreee🎜🎜5. JSON データの逆シリアル化🎜🎜🎜バイナリ JSON データを JSON オブジェクトに逆シリアル化するには、<code>json.Unmarshal
関数を使用します。 🎜rrreee🎜🎜実際的なケース🎜🎜🎜users
という名前のテーブルがあり、そのテーブルに json_data
という名前の JSON
列があるとします。 users
テーブルから json_data
列を取得するには: 🎜rrreee🎜 上記のコードは、users
テーブルの各行を反復処理し、json_data 列を JSON オブジェクトに逆シリアル化して、コンソールに出力します。 🎜以上がGolang でデータベースから JSON データを取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Go ではファイルを安全に読み書きすることが重要です。ガイドラインには以下が含まれます。 ファイル権限の確認 遅延を使用してファイルを閉じる ファイル パスの検証 コンテキスト タイムアウトの使用 これらのガイドラインに従うことで、データのセキュリティとアプリケーションの堅牢性が確保されます。

Apple の最新リリースの iOS18、iPadOS18、および macOS Sequoia システムでは、さまざまな理由で紛失または破損した写真やビデオをユーザーが簡単に回復できるように設計された重要な機能が写真アプリケーションに追加されました。この新機能では、写真アプリのツール セクションに「Recovered」というアルバムが導入され、ユーザーがデバイス上に写真ライブラリに含まれていない写真やビデオがある場合に自動的に表示されます。 「Recovered」アルバムの登場により、データベースの破損、カメラ アプリケーションが写真ライブラリに正しく保存されない、または写真ライブラリを管理するサードパーティ アプリケーションによって失われた写真やビデオに対する解決策が提供されます。ユーザーはいくつかの簡単な手順を実行するだけで済みます

MySQLは、オープンソースのリレーショナルデータベース管理システムです。 1)データベースとテーブルの作成:createdatabaseおよびcreateTableコマンドを使用します。 2)基本操作:挿入、更新、削除、選択。 3)高度な操作:参加、サブクエリ、トランザクション処理。 4)デバッグスキル:構文、データ型、およびアクセス許可を確認します。 5)最適化の提案:インデックスを使用し、選択*を避け、トランザクションを使用します。

バックエンド学習パス:フロントエンドからバックエンドへの探査の旅は、フロントエンド開発から変わるバックエンド初心者として、すでにNodeJSの基盤を持っています...

MySQLはオープンソースのリレーショナルデータベース管理システムであり、主にデータを迅速かつ確実に保存および取得するために使用されます。その実用的な原則には、クライアントリクエスト、クエリ解像度、クエリの実行、返品結果が含まれます。使用法の例には、テーブルの作成、データの挿入とクエリ、および参加操作などの高度な機能が含まれます。一般的なエラーには、SQL構文、データ型、およびアクセス許可、および最適化の提案には、インデックスの使用、最適化されたクエリ、およびテーブルの分割が含まれます。

大企業または有名なオープンソースプロジェクトによって開発されたGOのどのライブラリが開発されていますか? GOでプログラミングするとき、開発者はしばしばいくつかの一般的なニーズに遭遇します...

GO言語は、効率的でスケーラブルなシステムの構築においてうまく機能します。その利点には次のものがあります。1。高性能:マシンコードにコンパイルされ、速度速度が速い。 2。同時プログラミング:ゴルチンとチャネルを介してマルチタスクを簡素化します。 3。シンプルさ:簡潔な構文、学習コストとメンテナンスコストの削減。 4。クロスプラットフォーム:クロスプラットフォームのコンパイル、簡単な展開をサポートします。

Debian Systemsでは、GOのログローテーションは通常、GO標準ライブラリに付属する機能ではなく、サードパーティライブラリに依存しています。 Lumberjackは一般的に使用されるオプションです。さまざまなログフレームワーク(ZapやLogrusなど)で使用して、ログファイルの自動回転と圧縮を実現できます。 LumberJackおよびZAPライブラリを使用したサンプル構成:packagemainimport( "gopk.in/natefinch/lumberjack.v2" "go.uber.org/zap" "go.uber.org/zap/zapcor
