使用 Golang 建立 RESTful API 並使用 ORM 涉及以下步驟:使用 Gin 建立 API。安裝並使用 GORM 作為 ORM。定義資料模型並應用資料庫遷移。建立增刪改查 API 路由。使用 GORM 進行資料庫操作。部署 API 和前端應用程式。
RESTful API 是使用HTTP、URL 和JSON 等web 標準來與伺服器互動和獲取資料的現代應用程式介面的標準。在本文中,我們將學習如何使用 Golang 建立 RESTful API 並利用 ORM(物件關係映射器)來簡化與資料庫的互動。
go get github.com/gin-gonic/gin
main.go 的新檔案並編寫以下程式碼:
package main import ( "github.com/gin-gonic/gin" ) func main() { router := gin.Default() router.GET("/hello", func(c *gin.Context) { c.JSON(200, gin.H{ "message": "Hello, World!", }) }) router.Run() }
go run main.go,然後在瀏覽器中導航到
localhost:8080/hello。您應該會看到一條包含
Hello, World! 的 JSON 回應。
go get -u gorm.io/gorm
main.go 中,加入以下程式碼:
import ( "gorm.io/gorm" "gorm.io/driver/mysql" ) var DB *gorm.DB func connectDB() { // 替换 "user", "password", "dbname" 为实际值 dsn := "user:password@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local" db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{}) if err != nil { // 处理连接错误 } DB = db }
Todo 的資料模型:
type Todo struct { gorm.Model Task string Done bool }
go run main.go migrate
go run main.go migrate --migration-dir=./migrations up
// 创建 Todo router.POST("/todos", createTodo) // 获取所有 Todo router.GET("/todos", getTodos) // 获取指定 Todo router.GET("/todos/:id", getTodoByID) // 更新 Todo router.PUT("/todos/:id", updateTodo) // 删除 Todo router.DELETE("/todos/:id", deleteTodo)
func getTodos(c *gin.Context) { var todos []Todo if err := DB.Find(&todos).Error; err != nil { // 处理错误 } c.JSON(200, todos) }
以上是如何使用 Golang 建立 RESTful API 並使用 ORM?的詳細內容。更多資訊請關注PHP中文網其他相關文章!