検索
ホームページバックエンド開発GolangGo での MySQL の使用: 完全ガイド

Go での MySQL の使用: 完全ガイド

Jun 17, 2023 am 08:57 AM
mysqlgoガイド

インターネット アプリケーションの継続的な出現により、データベースは不可欠なコンポーネントになりました。 MySQL は最も人気のあるリレーショナル データベースの 1 つとして、開発に広く使用されています。 Go 言語でデータベース開発に MySQL を使用するにはどうすればよいですか?この記事では、Go 言語で MySQL を使用するために必要な完全なガイドを読者に詳しく紹介します。

1. MySQL ドライバーをインストールします: Go-MySQL-Driver

Go 言語で MySQL を使用するには、MySQL ドライバーをインストールする必要があります。現在、Go 言語は公式に SQL パッケージを提供していますが、MySQL ドライバーは提供していないため、サードパーティのライブラリを使用する必要があります。 Go-MySQL-Driver は、Go 言語によって公式に推奨されている MySQL ドライバーであり、Go 言語で MySQL を使用する場合に最適です。インストールは非常に簡単です。次のコードを使用してインストールできます。

go get -u github.com/go-sql-driver/mysql

2. MySQL データベースに接続します

MySQL を使用する前に、まず MySQL データベースに接続する必要があります。 MySQL データベースに接続するには、データベースの接続文字列を使用する必要があります。接続文字列には、ユーザー名、パスワード、アドレス、ポート番号、データベース名、その他の情報が含まれます。

MySQL データベースに接続するコード例は次のとおりです:

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

func openDB() (*sql.DB, error) {
  db, err := sql.Open("mysql", "user:password@tcp(127.0.0.1:3306)/database")
  if err != nil {
    return nil, err
  }
  return db, nil
}

コード分析:

sql.Open() メソッドを使用して MySQL 接続を開きます。最初のパラメータは MySQL ドライバ名で、2 番目のパラメータは MySQL データベースの接続文字列です。このうち、接続文字列にはユーザー名、パスワード、アドレス、ポート番号に関する情報が含まれており、最後の文字列はデータベース名です。

3. データ テーブルの作成

MySQL に接続したら、次はデータ テーブルを作成します。テーブルを操作するには、データベース オブジェクトを使用する必要があります。 Go 言語では、データベース オブジェクトは sql.DB 型であり、これを通じてデータ テーブルの作成、変更、削除などのデータベース操作を実行できます。

golang を使用してデータ テーブルを作成するコード例は次のとおりです:

func create() error {
  db, err := openDB()
  if err != nil {
    return err
  }
  defer db.Close()
  _, err = db.Exec(`
    CREATE TABLE IF NOT EXISTS Users (
      id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, 
      name VARCHAR(50) NOT NULL, 
      age INT NOT NULL, 
      email VARCHAR(50) NOT NULL
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  `)
  if err != nil {
    return err
  }
  return nil
}

コード分析:

コードはまず Open() を通じて MySQL データベースに接続します。メソッドを実行し、SQL コマンドでテーブルを作成する処理を実行する場合、MySQL コマンドは () を記述する必要があります。

4. データの挿入

データ テーブルを作成したら、次のステップはテーブルにデータを挿入することです。 Go 言語でデータを挿入するには、データベース オブジェクトの Exec() メソッドを使用する必要があります。

データを挿入するコード例は次のとおりです:

func insert() error {
  db, err := openDB()
  if err != nil {
    return err
  }
  defer db.Close()
  _, err = db.Exec("INSERT INTO Users (name, age, email) VALUES (?, ?, ?)", "Tom", 23, "tom@example.com")
  if err != nil {
    return err
  }
  return nil
}

コード分析:

データをデータベースに挿入するとき、Exec() メソッドの最初のパラメーターはSQLコマンド。変数値は、SQL コマンドにパラメータを渡すために使用されます。パラメータ名は疑問符 (?) で表されます。

5. データのクエリ

Go 言語は、Query() 関数を通じてデータベースにクエリを実行します。 Query() 関数のタイプは func Query(クエリ文字列, args...interface{}) です。最初のパラメータは SQL クエリ ステートメントであり、2 番目のパラメータは SQL クエリ ステートメントで必要なパラメータの値です。パラメータはカンマで区切ります。

データをクエリするコード例は次のとおりです:

func query() error {
  db, err := openDB()
  if err != nil {
    return err
  }
  defer db.Close()
  rows, err := db.Query("SELECT id, name, age, email FROM Users")
  if err != nil {
    return err
  }
  defer rows.Close()

  for rows.Next() {
    var id, age int
    var name, email string
    if err := rows.Scan(&id, &name, &age, &email); err != nil {
      return err
    }
    fmt.Println(id, name, age, email)
  }
  return nil
}

コード分析:

Query() メソッドを使用してクエリ操作を実行し、Scan() メソッドを使用します。行ごとに読み取ります データを取得します。

6. データの変更

Go 言語でデータを変更するには、データベース オブジェクトの Exec() メソッドを使用する必要があります。

データを変更するサンプル コードは次のとおりです。

func update() error {
  db, err := openDB()
  if err != nil {
    return err
  }
  defer db.Close()
  _, err = db.Exec("UPDATE Users SET age = ? WHERE name = ?", 25, "Tom")
  if err != nil {
    return err
  }
  return nil
}

コード分析:

Exec() メソッドを使用して変更操作を実行します。

7. データの削除

Go 言語でデータを削除するには、データベース オブジェクトの Exec() メソッドを使用し、DELETE ステートメントを実行する必要があります。

データを削除するサンプル コードは次のとおりです。

func delete() error {
  db, err := openDB()
  if err != nil {
    return err
  }
  defer db.Close()
  _, err = db.Exec("DELETE FROM Users WHERE name = ?", "Tom")
  if err != nil {
    return err
  }
  return nil
}

コード分析:

Exec() メソッドを使用して削除操作を実行します。

8. 概要

上記は、Go 言語で MySQL を使用するための完全なガイドであり、この記事を通じて、Go 言語と MySQL データベースを組み合わせるベスト プラクティスがわかります。 Go 言語での MySQL データベースの操作は非常にシンプルかつ直感的であり、Go 言語と MySQL の互換性は優れています。最後に、この記事が、Go 言語で MySQL を使用するスキルをよりよく理解し、習得するのに役立つことを願っています。

以上がGo での MySQL の使用: 完全ガイドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

Golangは実際のアプリケーションに優れており、そのシンプルさ、効率性、並行性で知られています。 1)同時プログラミングはゴルチンとチャネルを通じて実装されます。2)柔軟なコードは、インターフェイスと多型を使用して記述されます。3)ネット/HTTPパッケージを使用したネットワークプログラミングを簡素化、4)効率的な同時クローラーを構築する、5)ツールと最高の実践を通じてデバッグと最適化。

Golang:Goプログラミング言語が説明しましたGolang:Goプログラミング言語が説明しましたApr 10, 2025 am 11:18 AM

GOのコア機能には、ガベージコレクション、静的リンク、並行性サポートが含まれます。 1. GO言語の並行性モデルは、GoroutineとChannelを通じて効率的な同時プログラミングを実現します。 2.インターフェイスと多型は、インターフェイスメソッドを介して実装されているため、異なるタイプを統一された方法で処理できます。 3.基本的な使用法は、関数定義と呼び出しの効率を示しています。 4。高度な使用法では、スライスは動的なサイズ変更の強力な機能を提供します。 5.人種条件などの一般的なエラーは、Getest Raceを通じて検出および解決できます。 6.パフォーマンス最適化Sync.Poolを通じてオブジェクトを再利用して、ゴミ収集圧力を軽減します。

Golangの目的:効率的でスケーラブルなシステムの構築Golangの目的:効率的でスケーラブルなシステムの構築Apr 09, 2025 pm 05:17 PM

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

SQLソートのステートメントによる順序の結果がランダムに見えるのはなぜですか?SQLソートのステートメントによる順序の結果がランダムに見えるのはなぜですか?Apr 02, 2025 pm 05:24 PM

SQLクエリの結果の並べ替えについて混乱しています。 SQLを学習する過程で、しばしば混乱する問題に遭遇します。最近、著者は「Mick-SQL Basics」を読んでいます...

テクノロジースタックの収束は、テクノロジースタック選択のプロセスにすぎませんか?テクノロジースタックの収束は、テクノロジースタック選択のプロセスにすぎませんか?Apr 02, 2025 pm 05:21 PM

テクノロジースタックの収束とテクノロジーの選択の関係ソフトウェア開発におけるテクノロジーの選択、テクノロジースタックの選択と管理は非常に重要な問題です。最近、一部の読者が提案しています...

反射比較を使用し、GOの3つの構造の違いを処理する方法は?反射比較を使用し、GOの3つの構造の違いを処理する方法は?Apr 02, 2025 pm 05:15 PM

GO言語で3つの構造を比較および処理する方法。 GOプログラミングでは、2つの構造の違いを比較し、これらの違いを...

Goでグローバルにインストールされたパッケージを表示する方法は?Goでグローバルにインストールされたパッケージを表示する方法は?Apr 02, 2025 pm 05:12 PM

Goでグローバルにインストールされたパッケージを表示する方法は? GO言語で開発する過程で、GOはしばしば使用します...

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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

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

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

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

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

EditPlus 中国語クラック版

EditPlus 中国語クラック版

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

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。