検索
ホームページバックエンド開発GolangGo 言語でのデータ永続化と CRUD 操作

Go 言語でのデータ永続化と CRUD 操作

Jun 04, 2023 pm 03:10 PM
言語を移動データの永続性汚い操作

インターネットの発展に伴い、特に一部のデータ集約型アプリケーションでは、データの保存と使用がますます重要になってきています。 Go 言語は、新興プログラミング言語として、高速、安全、同時実行性、効率的な機能を備え、進化するデータ ウェアハウスとビッグ データのシナリオで徐々に登場しつつあります。この記事では、Go 言語でデータの永続化と CRUD 操作を実装する方法を紹介します。

ステップ 1: 適切なデータベースの選択

Go 言語には、PostgreSQL、SQLite、MySQL、MariaDB、MongoDB などを含む多くのデータベース ドライバーが用意されています。プログラムの作成を開始する前に、まずアプリケーションに適したデータベースを選択し、関連するドライバーについて学習を続ける必要があります。その中で最も一般的に使用されるのは次のとおりです。

  • SQL データベース: PostgreSQL、MySQL、SQLite、MariaDB。
  • NoSQL データベース: MongoDB など

ここでは、さまざまなデータベースの違いについては詳しく説明しません。簡単に言うと、リレーショナル データとの複雑な関係を確立する場合は、通常 SQL データベースの方が実用的ですが、半構造化データを管理する場合は NoSQL データベースが適しています。多次元データ クエリの効率的な処理が必要な場合には、より適している可能性があります。

ステップ 2: データベース ドライバーを作成する

Go 言語には、すべての Go プログラマーに統一された SQL インターフェイスを提供する、database/sql などの多くの組み込みデータベース ドライバーが用意されています。もちろん、データベースドライバーが異なれば実装されるインターフェースも異なります。

ここでは、MySQL データベースを例として、Go 言語でデータベース接続を確立する方法を説明します。 Go 言語のデータベース/SQL ドライバーは、さまざまなリレーショナル データベースに統合された SQL インターフェイスを提供するため、プログラマは関連するパラメーターを変更するだけで、アプリケーションでさまざまな種類のリレーショナル データベースを使用できます。次に、MySQL ドライバーの作成例を示します。

    import (
        "database/sql"
        _ "github.com/go-sql-driver/mysql"
    )

    func getDatabaseConnection() (*sql.DB, error) {
        db, err := sql.Open("mysql", "root:@tcp(127.0.0.1:3306)/test")
        return db, err
    }

上記のコードでは、MySQL ドライバーが import を使用して導入されていることがわかります。次に、sql.Open() メソッドを使用してデータベース接続を確立し、アカウント番号、パスワード、ホスト アドレス、ポート番号などの接続パラメータを渡します。ここでは、パスワードなしの root アカウントを使用しています。ホスト アドレスは 127.0.0.1、ポート番号は 3306、データベース名は ## です。 #テスト## #。 プロセスが完了したら、

db.Ping()

メソッドを呼び出してデータベースに正常に接続したかどうかをテストし、* 型の接続オブジェクトを返す必要があります。 SQL.DBステップ 3: CRUD 操作を実行する

データベース接続を確立したので、CRUD 操作を実行できます。 CRUD 操作は、それぞれ追加 (Create)、読み取り (Read)、更新 (Update)、および削除 (Delete) を表します。これらの操作には通常、データベース内のテーブルのデータの読み取り、クエリ、変更、削除が含まれます。

以下は簡単な CRUD の例です。これにより、「id、name、age」という 3 つのフィールドを持つレコードをデータベースに追加できます。

    func createUser(newUser User) error {
        db, err := getDatabaseConnection()
        if err != nil {
            return err
        }
        defer db.Close()

        _, err = db.Exec("INSERT INTO users(name, age) VALUES(?, ?)", newUser.Name, newUser.Age)
        if err != nil {
            return err
        }
        return nil
    }

上記のコードでは、## が使用されています。 #db.Exec()

メソッドはデータベースにデータを書き込みます。このうち、

? は動的バインディングパラメータです。このようにして、プリコンパイルされた SQL クエリ ステートメントに対応するパラメータが自動的に入力されるため、プログラムのセキュリティが確保されます。 db.Query() メソッドを使用して、データベースからクエリ操作を実行することもできます。

    func getUserByID(id int64) (*User, error) {
        db, err := getDatabaseConnection()
        if err != nil {
            return nil, err
        }
        defer db.Close()

        row := db.QueryRow("SELECT id, name, age FROM users WHERE id = ?", id)

        user := new(User)
        err = row.Scan(&user.ID, &user.Name, &user.Age)
        if err != nil {
            return nil, err
        }

        return user, nil
    }

上記の例では、db.QueryRow() メソッドを使用してクエリを実行し、クエリ結果を

row

オブジェクトに記録します。

row.Scan() メソッドを使用して、クエリ結果の特定の列の値を User 構造体に入力します (User 構造体にフィールド ID、名前、年齢 )。 概要

Web アプリケーションの構築、大規模なデータ セットの処理、分散システムの構築のいずれの場合でも、Go 言語は確実な選択肢です。この記事では、Go 言語とさまざまな種類のデータベースを使用してデータの永続化と CRUD 操作を構築する方法を説明しました。データベース アプリケーションを構築する必要がある場合でも、データ分析を実行する必要がある場合でも、高性能で大規模なアプリケーションを設計する必要がある場合でも、Go は無敵の選択肢です。

以上がGo 言語でのデータ永続化と CRUD 操作の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
GOインターフェイスでアサーションとタイプスイッチを入力しますGOインターフェイスでアサーションとタイプスイッチを入力しますMay 02, 2025 am 12:20 AM

gohandlesinterfacesandtypeassertionseffectivivivivivity、強化された柔軟性と耐毒性を強化します

エラーを使用し、エラーを使用して、goでエラー検査を行いますエラーを使用し、エラーを使用して、goでエラー検査を行いますMay 02, 2025 am 12:11 AM

言語エラー処理は、エラーとエラーを介してより柔軟になり、読みやすくなります。 1.エラーは、エラーが指定されたエラーと同じであり、エラーチェーンの処理に適しているかどうかを確認するために使用されます。 2.エラー。エラータイプを確認するだけでなく、エラーを特定のタイプに変換することもできます。これは、エラー情報を抽出するのに便利です。これらの関数を使用すると、エラー処理ロジックを簡素化できますが、エラーチェーンの正しい配信に注意を払い、コードの複雑さを防ぐために過度の依存性を回避できます。

GOのパフォーマンスチューニング:アプリケーションの最適化GOのパフォーマンスチューニング:アプリケーションの最適化May 02, 2025 am 12:06 AM

tomakegogoapplicationsRunfasterAndMore -efficient、useprofilingtools、leverageconconcurrency、andmanagememoryefcectively.1)useprofforcpuandmemoryprofilingtoidentififybottlenecks.2)

GOの未来:トレンドと開発GOの未来:トレンドと開発May 02, 2025 am 12:01 AM

go'sfutureisbrightwithtrendslikeRikeRovedTooling、generics、cloud-nativeadoption、performulenhancements、andwebassemblyintegration、butchallengesincludemaintainingsimplicitandimplovingeror handling。

Goroutinesの理解:Goの同時性に深く潜りますGoroutinesの理解:Goの同時性に深く潜りますMay 01, 2025 am 12:18 AM

GoroutinesAreSareSareSareSormethodSthaturncurlyntingo、Enableing and LightweightConcurrency.1)theyRuntimeSimeSingMultiplexing、SountyStorunonFeweroSthReads.2)ゴルチンズを失ったことを許可します

go:目的と使用法でのinit機能を理解するgo:目的と使用法でのinit機能を理解するMay 01, 2025 am 12:16 AM

initistoistoInitializevariables、setupconutupurations、orforformndexedarysetupbe foreThemainfunctionexecutes.useinitby:1)inginginyourcodeTorunautorunaintalunain、2)KeepingItshortandpocusedonsimpletasks、3)ConsididiriveSusinginsingingingingingingingingingingingingingingingingingingingingingingsingpltassksを使用すると、

GOインターフェイスの理解:包括的なガイドGOインターフェイスの理解:包括的なガイドMay 01, 2025 am 12:13 AM

go interfacesaremethodsignaturesetsetsattypesmustimplement、unableingpolymorphism withintinheritance forcleaner、modularcode.theyareimplictilistifisisfiestified、houseforfflexibleapisanddeaupling、busrecarefulusoavoidoidoimoidimeerrororsypertety。

GOのパニックからの回復:いつ、どのように使用するか()GOのパニックからの回復:いつ、どのように使用するか()May 01, 2025 am 12:04 AM

Goで回復()関数を使用して、パニックから回復します。特定の方法は次のとおりです。1)回復()を使用して、延期関数でパニックをキャプチャして、プログラムのクラッシュを避けます。 2)デバッグの詳細なエラー情報を記録します。 3)特定の状況に基づいてプログラムの実行を再開するかどうかを決定します。 4)パフォーマンスに影響を及ぼさないように注意して使用します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター