Golang を使用して RESTful API を構築し、MySQL データベースに接続します: Golang、MySQL ドライバーをインストールし、プロジェクトを作成します。すべてのユーザーと特定のユーザーの取得を含む API ハンドラーを定義します。 sql.Open 関数を通じて MySQL データベースに接続します。 db.Query と db.QueryRow を使用してデータベースからデータを取得します。 json.NewEncoder を使用して JSON 応答を書き込みます。オプション: 新しいユーザーを作成するためのコード例を提供します。
Golang を使用して RESTful API を構築し、MySQL データベースに接続する方法
はじめに
RESTful API は、クライアントとサーバー間の対話を簡素化する HTTP プロトコルに基づく API タイプです。 Golang を使用して RESTful API を構築すると、その高いパフォーマンスと同時実行性を最大限に活用できます。この記事では、Golang を使用して RESTful API を構築し、MySQL データベースに接続する方法を説明します。
前提条件
- Golang がインストールされていること (バージョン 1.18 以降)
- MySQL データベースと MySQL ドライバー (
github.com/go-sql-driver/mysql
)github.com/go-sql-driver/mysql
) - 文本编辑器或 IDE(如 Visual Studio Code)
构建 RESTful API
-
创建新项目:使用
go mod init
命令创建新项目。 -
安装 MySQL 驱动程序:使用
go get -u github.com/go-sql-driver/mysql
命令安装 MySQL 驱动程序。 -
编写 API 处理程序:在
main.go
文件中编写以下 API 处理程序:
package main import ( "database/sql" "log" "net/http" "strconv" "github.com/go-sql-driver/mysql" ) const ( user = "root" password = "" host = "localhost" port = 3306 database = "my_db" ) var db *sql.DB func init() { dsn := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?parseTime=true", user, password, host, port, database) var err error db, err = sql.Open("mysql", dsn) if err != nil { log.Fatal(err) } } func main() { http.HandleFunc("/users", handleUsers) http.HandleFunc("/users/", handleUser) log.Fatal(http.ListenAndServe(":8080", nil)) }
-
连接到 MySQL 数据库:使用
sql.Open
函数连接到 MySQL 数据库。 -
定义路由处理程序:使用
http.HandleFunc
函数定义两个路由处理程序:/users
和/users/:id
。 -
运行服务器:使用
http.ListenAndServe
函数启动服务器。
处理用户请求
-
获取所有用户:在
/users
处理程序中,使用db.Query
函数从数据库中获取所有用户。 -
获取特定用户:在
/users/:id
处理程序中,使用db.QueryRow
函数从数据库中获取特定用户。 -
编写响应:使用
json.NewEncoder
函数将用户数据编码为 JSON 并写入到 HTTP 响应中。
实战案例
假设你的 MySQL 数据库中有名为 users
ul>
RESTful API を構築する
- 🎜 新しいプロジェクトを作成する: 🎜
go mod init <project name></project>
コマンドを使用して新しいプロジェクトを作成します。 🎜🎜🎜MySQL ドライバーをインストールします: 🎜 go get -u github.com/go-sql-driver/mysql
コマンドを使用して、MySQL ドライバーをインストールします。 🎜🎜🎜 API ハンドラーを作成します: 🎜 main.go
ファイルに次の API ハンドラーを作成します: 🎜CREATE TABLE users ( id INT NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL, email VARCHAR(255) NOT NULL, PRIMARY KEY (id) );
- 🎜🎜 MySQL データベースに接続します: 🎜
sql.Open
関数を使用して MySQL データベースに接続します。 🎜🎜🎜ルート ハンドラーを定義します: 🎜 http.HandleFunc
関数を使用して、2 つのルート ハンドラー /users
と /users/:id
を定義します。 🎜🎜🎜サーバーを実行します: 🎜 http.ListenAndServe
関数を使用してサーバーを起動します。 🎜- 🎜🎜すべてのユーザーを取得: 🎜
/users
ハンドラーで、db.Query
関数を使用して取得します。データベースからすべてのユーザーを取得します。 🎜🎜🎜特定のユーザーを取得する: 🎜 /users/:id
ハンドラーで、db.QueryRow
関数を使用してデータベースから特定のユーザーを取得します。 🎜🎜🎜レスポンスの書き込み: 🎜 json.NewEncoder
関数を使用して、ユーザー データを JSON にエンコードし、HTTP レスポンスに書き込みます。 🎜users
という名前のテーブルがあるとします。 🎜func handleCreateUser(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 } stmt, err := db.Prepare("INSERT INTO users (name, email) VALUES (?, ?);") if err != nil { log.Fatal(err) } defer stmt.Close() res, err := stmt.Exec(user.Name, user.Email) if err != nil { log.Fatal(err) } id, err := res.LastInsertId() if err != nil { log.Fatal(err) } user.ID = int(id) json.NewEncoder(w).Encode(user) }🎜 次のコードを使用して新しいユーザーを作成し、データベースに追加します: 🎜rrreee🎜🎜注: 🎜データベース接続情報とクロスドメインリクエストに関連する処理メカニズムを更新することを忘れないでください。 🎜
以上がGolang を使用して RESTful API を構築し、MySQL データベースに接続するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

GolangisidealforBuildingsCalables Systemsduetoitsefficiency andConcurrency、Whilepythonexcelsinquickscriptinganddataanalysisduetoitssimplicityand vastecosystem.golang'ssignencouragesclean、readisinediteNeditinesinedinediseNabletinedinedinedisedisedioncourase

Golangは並行性がCよりも優れていますが、Cは生の速度ではGolangよりも優れています。 1)Golangは、GoroutineとChannelを通じて効率的な並行性を達成します。これは、多数の同時タスクの処理に適しています。 2)Cコンパイラの最適化と標準ライブラリを介して、極端な最適化を必要とするアプリケーションに適したハードウェアに近い高性能を提供します。

Golangを選択する理由には、1)高い並行性パフォーマンス、2)静的タイプシステム、3)ガベージ収集メカニズム、4)豊富な標準ライブラリとエコシステムは、効率的で信頼できるソフトウェアを開発するための理想的な選択肢となります。

Golangは迅速な発展と同時シナリオに適しており、Cは極端なパフォーマンスと低レベルの制御が必要なシナリオに適しています。 1)Golangは、ごみ収集と並行機関のメカニズムを通じてパフォーマンスを向上させ、高配列Webサービス開発に適しています。 2)Cは、手動のメモリ管理とコンパイラの最適化を通じて究極のパフォーマンスを実現し、埋め込みシステム開発に適しています。

Golangは、コンピレーション時間と同時処理においてより良いパフォーマンスを発揮しますが、Cはランニング速度とメモリ管理においてより多くの利点があります。 1.Golangの編集速度は速く、迅速な発展に適しています。 2.Cは速く実行され、パフォーマンスクリティカルなアプリケーションに適しています。 3. Golangは、同時処理においてシンプルで効率的で、同時プログラミングに適しています。 4.Cマニュアルメモリ管理により、パフォーマンスが高くなりますが、開発の複雑さが向上します。

WebサービスとシステムプログラミングへのGolangのアプリケーションは、主にそのシンプルさ、効率性、並行性に反映されています。 1)Webサービスでは、Golangは、強力なHTTPライブラリと同時処理機能を介して、高性能WebアプリケーションとAPIの作成をサポートしています。 2)システムプログラミングでは、Golangはハードウェアに近い機能とC言語との互換性を使用して、オペレーティングシステムの開発と組み込みシステムに適しています。

GolangとCには、パフォーマンスの比較に独自の利点と欠点があります。1。ゴーランは、高い並行性と迅速な発展に適していますが、ごみ収集はパフォーマンスに影響を与える可能性があります。 2.Cは、パフォーマンスとハードウェア制御を高くしますが、開発の複雑さが高くなります。選択を行うときは、プロジェクトの要件とチームのスキルを包括的な方法で考慮する必要があります。

Golangは、高性能および同時プログラミングシナリオに適していますが、Pythonは迅速な開発とデータ処理に適しています。 1.Golangは、シンプルさと効率性を強調し、バックエンドサービスとマイクロサービスに適しています。 2。Pythonは、データサイエンスと機械学習に適した簡潔な構文とリッチライブラリで知られています。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

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

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

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

ホットトピック









