新闻中心
Golang 如何做一个图书管理系统_Golang CRUD 操作与数据库集成示例
答案:使用Golang和MySQL实现图书管理系统,通过database/sql包和go-sql-driver/mysql驱动完成数据库连接,定义Book结构体对应数据表字段,封装增删改查操作并测试。

用 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 中创建数据库和图书表:
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)
<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)
Reachout.ai
一个AI驱动的视频开发平台,专为忙碌的企业家和销售团队打造
142
查看详情
<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 boo
ks []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 操作与数据库集成示例的详细内容,更多请关注其它相关文章!
# 中文网
# 视觉营销完成校园推广
# 网站建设及推广优化策略
# 常州台州网站建设
# 安徽谷歌网站推广
# 网站竞价推广只信a火20星
# 深圳网络营销推广报价
# 网站与seo
# 江门网站推广计划
# 网站 建设哪家好
# 做网站建设推广方案范文
# 可选
# 解决问题
# 分页
# 做一个
# mysql
# 相关文章
# 查询结果
# 如何做一个
# 绑定
# 图书管理系统
# 持久化存储
# ai
# app
# go语言
# golang
# github
# go
# git
# word
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
Python多线程中正确使用sigwait处理SIGALRM信号
J*a实现学校排课程序_面向对象结构化项目示例
使用CSS更改登录屏幕输入框中PNG图标颜色的策略与局限性
Win11输入法不见了怎么办_Windows11恢复语言栏显示方法
ACG动漫手机版官网入口 手机ACG动漫APP在线观看正版
Win11怎么开启卓越性能模式 Win11电源选项启用高性能释放硬件潜力【方法】
J*aScript井字棋(Tic-Tac-Toe)核心交互逻辑实现教程
怎么去除衣服上的口红印_生活小妙招教你用酒精轻松擦除
CSS实现侧边栏导航项全宽圆角悬停背景效果
qq浏览器打开空白页怎么办 qq浏览器启动后显示白屏的解决教程
QQ邮箱网页版登录入口 QQ邮箱官方在线使用平台
Pandas DataFrame:高效添加条件计算列
Word2013如何插入视频和音频媒体_Word2013媒体插入的多媒体支持
漫蛙MANWA漫画主页官方入口 漫蛙漫画最新在线阅读地址
离线运行Go语言之旅:本地部署与GOPATH配置指南
12306选座如何查看座位示意图_12306座位示意图解读与使用
淘宝网网页版登录入口 淘宝官方网页版快捷登录
Win11怎么修改默认浏览器_Windows 11设置Chrome为默认
Angular响应式表单:实现提交后表单及按钮的禁用与只读化
J*aScript中管理异步API调用:确保操作顺序与数据一致性
汽水音乐网页版使用入口_汽水音乐电脑版播放指南
支付宝碰一碰设备是REDMI手机吗 博主拆机辟谣:处理器、内存都不一样
高德地图沿途添加点失败如何解决 高德多点规划方法
Win11怎么设置鼠标主按键_Win11鼠标左右键功能互换
MAC如何安全彻底地删除文件_MAC使用终端命令确保文件无法被恢复
J*aScript数据结构转换:将对象数组按类别分组
b站怎么删除评论_b站评论管理与删除操作
如何使 Jest 模拟函数默认抛出错误以提高测试效率
LINUX的perf命令入门_LINUX官方性能分析工具的使用与解读
QQ邮箱官网登录入口 QQ邮箱网页版邮箱快速登录
谷歌邮箱网页版官方页面入口 谷歌邮箱网页端快速访问
c++ 获取系统当前时间 c++时间戳获取方法
J*aScript map 方法中处理循环元素为空数组的策略
韩小圈电脑版在线入口_网页版免费登录地址
Mac怎么使用表情符号_Mac Emoji快捷键面板
steam官方入口大全 steam账号注册及操作指南
如何在CSS中使用浮动制作导航栏_float实现水平菜单
C++如何操作大型数据集_使用C++流式处理(Streaming)技术避免一次性加载大文件
12306几点到几点不能订票? | 官方最新系统维护时间全解析
谷歌google账号怎么注册账号 谷歌账号注册官方流程
C++如何比较两个字符串_C++ string compare函数与操作符对比
J*a递归快速排序中静态变量导致数据累积问题的解决方案
C++如何使用AddressSanitizer(ASan)_C++调试工具中检测内存访问错误的利器
必由学网页版入口 必由学官方平台直接访问
黑猫投诉统一入口官网 消费者权益保护投诉平台
火狐浏览器占用内存高卡顿怎么办 火狐浏览器性能优化设置技巧
Tailwind CSS line-clamp 布局问题解析与修复指南
jQuery Mask 插件中实现电话号码固定前导零的教程
Typer应用中灵活处理命令行参数的令牌化与解析
12306选座怎么选到特殊座位_12306特殊座位选择注意事项


2025-11-15
浏览次数:次
返回列表
ks []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>