Go 入门实战:音乐专辑管理 API

作为 Go 新手,光看语法很难真正掌握编程。通过实践一个小项目,你可以同时了解 Go 基础语法、数据库操作和 Web 开发

数据库设计

sql 复制代码
CREATE DATABASE IF NOT EXISTS music_store;
USE music_store;

CREATE TABLE IF NOT EXISTS albums (
    id VARCHAR(255) NOT NULL PRIMARY KEY,
    title VARCHAR(255) NOT NULL,
    artist VARCHAR(255) NOT NULL,
    price DECIMAL(10,2) NOT NULL
);

INSERT INTO albums (id, title, artist, price) VALUES
('1', 'Blue Train', 'John Coltrane', 56.99),
('2', 'Jeru', 'Gerry Mulligan', 17.99),
('3', 'Sarah Vaughan and Clifford Brown', 'Sarah Vaughan', 39.99);

代码示例

go 复制代码
package main

import (
    "fmt"
    "net/http"

    "github.com/gin-gonic/gin"
    "gorm.io/driver/mysql"
    "gorm.io/gorm"
)

// Album 结构体映射到 albums 表
type Album struct {
    ID     string  `json:"id" gorm:"primaryKey"`
    Title  string  `json:"title"`
    Artist string  `json:"artist"`
    Price  float64 `json:"price"`
}

var db *gorm.DB
var err error

// 初始化数据库连接
func initDB() {
    dsn := "root:123456@tcp(127.0.0.1:3306)/music_store"
    db, err = gorm.Open(mysql.Open(dsn), &gorm.Config{})
    if err != nil {
        fmt.Println("数据库连接失败:", err)
        panic(err)
    }
    fmt.Println("数据库连接成功")
}

// 获取所有专辑
func getAlbums(c *gin.Context) {
    var albums []Album

    db.Find(&albums)

    c.IndentedJSON(http.StatusOK, albums)
}

// 根据 ID 获取单个专辑
func getAlbumByID(c *gin.Context) {
    id := c.Param("id")
    var album Album

    result := db.First(&album, "id = ?", id)
    if result.Error != nil {
        c.JSON(http.StatusNotFound, gin.H{"message": "专辑未找到"})
        return
    }

    c.IndentedJSON(http.StatusOK, album)
}

// 新增专辑
func postAlbum(c *gin.Context) {
    var newAlbum Album

    if err := c.BindJSON(&newAlbum); err != nil {
        c.JSON(http.StatusBadRequest, gin.H{"message": "无效请求"})
        return
    }

    db.Create(&newAlbum)

    c.IndentedJSON(http.StatusCreated, newAlbum)
}

func main() {
    initDB()

    router := gin.Default()

    // 路由绑定
    router.GET("/albums", getAlbums)
    router.GET("/albums/:id", getAlbumByID)
    router.POST("/albums", postAlbum)

    router.Run("localhost:8080")
}

测试 API

启动服务后,可使用 curl 测试接口:

  1. 获取所有专辑:
bash 复制代码
curl http://localhost:8080/albums
  1. 获取单个专辑:
bash 复制代码
curl http://localhost:8080/albums/2
  1. 新增专辑:
bash 复制代码
curl -X POST http://localhost:8080/albums \
-H "Content-Type: application/json" \
-d '{"id":"4","title":"New Album","artist":"New Artist","price":29.99}'
相关推荐
hssfscv40 分钟前
Javaweb学习笔记——后端实战7 springAOP
笔记·后端·学习
消失的旧时光-194341 分钟前
第九课实战版:异常与日志体系 —— 后端稳定性的第一道防线
java·后端
麦聪聊数据1 小时前
LiveOps事故零容忍:游戏行业数据库的细粒度权限管控与审计实践
运维·数据库·后端·sql
shepherd1261 小时前
深度剖析SkyWalking:从内核原理到生产级全链路监控实战
分布式·后端·skywalking
橘子师兄1 小时前
C++AI大模型接入SDK—Genimi接入封装
c++·人工智能·后端
码农水水2 小时前
大疆Java面试被问:使用Async-profiler进行CPU热点分析和火焰图解读
java·开发语言·jvm·数据结构·后端·面试·职场和发展
ahauedu2 小时前
SpringBoot 3.5.10引入springdoc-openapi-starter-webmvc-ui版本
java·spring boot·后端
未来龙皇小蓝2 小时前
Spring内置常见线程池配置及相关概念
java·后端·spring·系统架构
新缸中之脑2 小时前
Google:Rust实战评估
开发语言·后端·rust
一 乐2 小时前
在线考试|基于springboot + vue在线考试系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计