本教學向您展示如何使用 Golang、Gin 框架和 PostgreSQL 建立一個簡單的 CRUD(建立、讀取、更新、刪除)應用程式。 您將學習管理儲存在 PostgreSQL 資料庫中的資料。
目錄
- 簡介
- 先決條件
- 專案結構
- 項目設定
- 資料庫與表格建立
- 實作 CRUD 處理程序
- API 檢定
- 結論
1。簡介
本指南利用 Gin(一個輕量級 Golang Web 框架)來建立 API 端點。 該應用程式透過 pgx 驅動程式與 PostgreSQL 資料庫互動。 假設您基本上熟悉 Golang 和 REST API。
2。先決條件
開始之前,請確保您擁有:
- Golang(1.20 或更高版本)
- PostgreSQL(任何版本)
- Postman(或類似的 API 測試工具)
- 程式碼編輯器(例如 VS Code)
3。專案結構
如下整理您的專案:
<code>crud-app/ ├── main.go ├── config/ │ └── database.go ├── controllers/ │ └── item.go ├── models/ │ └── item.go ├── routes/ │ └── routes.go ├── go.mod └── go.sum </code>
4。項目設定
-
建立專案目錄並初始化Go模組:
mkdir crud-app cd crud-app go mod init github.com/yourusername/crud-app // Replace with your GitHub username
-
安裝必要的軟體包:
go get github.com/gin-gonic/gin go get github.com/jackc/pgx/v5
5。建立資料庫和表格
-
建立 PostgreSQL 資料庫(例如
crud_app
)。 -
連接資料庫並建立
items
表:CREATE DATABASE crud_app; \c crud_app CREATE TABLE items ( id SERIAL PRIMARY KEY, name TEXT NOT NULL, description TEXT, price NUMERIC(10, 2) );
6。實作 CRUD 處理程序
6.1 資料庫連線(config/database.go):
package config import ( "database/sql" "fmt" "log" _ "github.com/jackc/pgx/v5/stdlib" ) var DB *sql.DB func ConnectDatabase() { // ... (Connection string with your credentials) ... }
6.2 模型定義 (models/item.go):
package models type Item struct { ID int `json:"id"` Name string `json:"name"` Description string `json:"description"` Price float64 `json:"price"` }
6.3 CRUD 處理程序 (controllers/item.go): (範例:建立)
package controllers import ( "crud-app/config" "crud-app/models" "github.com/gin-gonic/gin" "net/http" ) func CreateItem(c *gin.Context) { // ... (Implementation for creating a new item) ... }
實作類似的功能來讀取、更新和刪除項目。
6.4 路線定義 (routes/routes.go):
package routes import ( "crud-app/controllers" "github.com/gin-gonic/gin" ) func SetupRoutes(router *gin.Engine) { router.POST("/items", controllers.CreateItem) // ... (Add routes for other CRUD operations) ... }
6.5 主應用程式(main.go):
package main import ( "crud-app/config" "crud-app/routes" "github.com/gin-gonic/gin" ) func main() { config.ConnectDatabase() r := gin.Default() routes.SetupRoutes(r) r.Run(":8080") }
7。 API 測試
執行應用程式 (go run main.go
) 並使用 Postman 或類似工具測試端點。
8。結論
您已經成功建立了一個基本的 CRUD 應用程式。請記住填寫缺少的 CRUD 處理程序實作並根據您的環境調整資料庫連接字串。 這個基礎可以透過更進階的功能進行擴充。
以上是如何使用 Golang、Gin 和 PostgreSQL 建立 CRUD 應用程式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文討論了使用GO的“字符串”軟件包進行字符串操作,詳細介紹了共同的功能和最佳實踐,以提高效率並有效地處理Unicode。

本文詳細介紹了GO的“時間”包用於處理日期,時間和時區,包括獲得當前時間,創建特定時間,解析字符串以及測量經過的時間。

文章討論了使用GO的“同步/原子”軟件包進行並行編程中的原子操作,詳細說明了其益處,例如防止比賽條件和提高性能。

本文討論了GO中的類型轉換,包括語法,安全轉換實踐,常見的陷阱和學習資源。它強調明確的類型轉換和錯誤處理。 [159個字符]

本文解釋了在GO中使用“選擇”語句來處理多個頻道操作的使用,其與“開關”語句的差異以及常見用例,例如處理多個渠道,實現超時,非B


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。