首页 > 后端开发 > Golang > 正文

Golang 如何做一个图书管理系统_Golang CRUD 操作与数据库集成示例

P粉602998670
发布: 2025-11-15 19:26:02
原创
928人浏览过
答案:使用Golang和MySQL实现图书管理系统,通过database/sql包和go-sql-driver/mysql驱动完成数据库连接,定义Book结构体对应数据表字段,封装增删改查操作并测试。

golang 如何做一个图书管理系统_golang crud 操作与数据库集成示例

用 Golang 做一个图书管理系统,核心是实现对图书数据的增删改查(CRUD)并连接数据库持久化存储。下面以 MySQL 为例,演示如何使用 Go 的 database/sql 包和第三方驱动 go-sql-driver/mysql 完成一个简单的图书管理系统。

1. 环境准备与依赖安装

确保已安装 Go 和 MySQL。创建项目目录后,初始化模块:

mkdir book-manager<br>cd book-manager<br>go mod init book-manager
登录后复制

安装 MySQL 驱动:

go get -u github.com/go-sql-driver/mysql
登录后复制

2. 数据库设计与建表

在 MySQL 中创建数据库和图书表:

立即学习go语言免费学习笔记(深入)”;

CREATE DATABASE bookdb;<br>USE bookdb;<br><br>CREATE TABLE books (<br>    id INT AUTO_INCREMENT PRIMARY KEY,<br>    title VARCHAR(255) NOT NULL,<br>    author VARCHAR(255) NOT NULL,<br>    isbn VARCHAR(13) UNIQUE NOT NULL,<br>    published_year YEAR,<br>    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP<br>);
登录后复制

3. 定义图书结构体与数据库连接

创建 main.go 文件,定义 Book 结构体并初始化数据库连接:

<font face="Courier New">package main

import (
    "database/sql"
    "fmt"
    "log"

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

type Book struct {
    ID             int
    Title          string
    Author         string
    ISBN           string
    PublishedYear  int
    CreatedAt      string
}

var db *sql.DB

func initDB() {
    var err error
    dsn := "root:yourpassword@tcp(127.0.0.1:3306)/bookdb"
    db, err = sql.Open("mysql", dsn)
    if err != nil {
        log.Fatal(err)
    }
    if err = db.Ping(); err != nil {
        log.Fatal(err)
    }
    fmt.Println("数据库连接成功")
}</font>
登录后复制

4. 实现 CRUD 操作函数

添加以下函数实现基本操作:

插入图书(Create)

乾坤圈新媒体矩阵管家
乾坤圈新媒体矩阵管家

新媒体账号、门店矩阵智能管理系统

乾坤圈新媒体矩阵管家 17
查看详情 乾坤圈新媒体矩阵管家
<font face="Courier New">func createBook(book Book) {
    query := `INSERT INTO books (title, author, isbn, published_year) VALUES (?, ?, ?, ?)`
    result, err := db.Exec(query, book.Title, book.Author, book.ISBN, book.PublishedYear)
    if err != nil {
        log.Fatal(err)
    }
    id, _ := result.LastInsertId()
    fmt.Printf("图书插入成功,ID: %d\n", id)
}</font>
登录后复制

查询所有图书(Read)

<font face="Courier New">func getAllBooks() []Book {
    rows, err := db.Query("SELECT id, title, author, isbn, published_year, created_at FROM books")
    if err != nil {
        log.Fatal(err)
    }
    defer rows.Close()

    var books []Book
    for rows.Next() {
        var b Book
        err := rows.Scan(&b.ID, &b.Title, &b.Author, &b.ISBN, &b.PublishedYear, &b.CreatedAt)
        if err != nil {
            log.Fatal(err)
        }
        books = append(books, b)
    }
    return books
}</font>
登录后复制

根据 ID 查询图书

<font face="Courier New">func getBookByID(id int) Book {
    var b Book
    query := "SELECT id, title, author, isbn, published_year, created_at FROM books WHERE id = ?"
    err := db.QueryRow(query, id).Scan(
        &b.ID, &b.Title, &b.Author, &b.ISBN, &b.PublishedYear, &b.CreatedAt,
    )
    if err != nil {
        log.Fatal(err)
    }
    return b
}</font>
登录后复制

更新图书(Update)

<font face="Courier New">func updateBook(book Book) {
    query := `UPDATE books SET title=?, author=?, isbn=?, published_year=? WHERE id=?`
    _, err := db.Exec(query, book.Title, book.Author, book.ISBN, book.PublishedYear, book.ID)
    if err != nil {
        log.Fatal(err)
    }
    fmt.Printf("图书 ID %d 更新成功\n", book.ID)
}</font>
登录后复制

删除图书(Delete)

<font face="Courier New">func deleteBook(id int) {
    query := "DELETE FROM books WHERE id = ?"
    _, err := db.Exec(query, id)
    if err != nil {
        log.Fatal(err)
    }
    fmt.Printf("图书 ID %d 删除完成\n", id)
}</font>
登录后复制

5. 编写主函数测试功能

main() 中调用上述函数:

<font face="Courier New">func main() {
    initDB()
    defer db.Close()

    // 插入新书
    newBook := Book{
        Title:          "Go语言编程",
        Author:         "谢孟军",
        ISBN:           "9787121227579",
        PublishedYear:  2018,
    }
    createBook(newBook)

    // 查询全部
    books := getAllBooks()
    for _, b := range books {
        fmt.Printf("书名: %s, 作者: %s, ISBN: %s\n", b.Title, b.Author, b.ISBN)
    }

    // 更新图书
    bookToUpdate := books[0]
    bookToUpdate.Title = "Go语言实战"
    updateBook(bookToUpdate)

    // 删除图书(可选)
    // deleteBook(1)
}</font>
登录后复制

运行程序:

go run main.go
登录后复制

基本上就这些。通过这个示例,你已经实现了 Golang 图书管理系统的基础 CRUD 功能,并完成了与 MySQL 的集成。后续可扩展加入 Web 接口(如使用 Gin 框架)、输入验证、分页查询等功能。

以上就是Golang 如何做一个图书管理系统_Golang CRUD 操作与数据库集成示例的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号