Go语言:用Go操作SQLite详解

文章目录

一、驱动选择

Go语言通过标准库database/sql结合第三方驱动可以方便地操作SQLite数据库。Go语言支持SQLite的驱动较多,但推荐使用支持database/sql接口的驱动,例如github.com/mattn/go-sqlite3。该驱动功能完善,兼容性强,是Go语言操作SQLite的主流选择。

官方文档:https://mattn.github.io/go-sqlite3/

二、数据库连接

2.1 安装驱动

首先,通过以下命令安装go-sqlite3驱动:

bash 复制代码
go get github.com/mattn/go-sqlite3

2.2 连接数据库

以下代码展示了如何连接SQLite数据库:

go 复制代码
package main
import (
	"database/sql"
	"fmt"
	"log"
	_ "github.com/mattn/go-sqlite3"
)
func main() {
	// 打开数据库连接,如果数据库不存在会自动创建
	db, err := sql.Open("sqlite3", "./test.db")
	if err != nil {
		log.Fatal(err)
	}
	defer db.Close()
	// 检查连接是否成功
	err = db.Ping()
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println("成功连接到SQLite数据库")
}

三、表操作

3.1 创建表

以下代码展示了如何创建一个用户表:

go 复制代码
func createTable(db *sql.DB) {
	query := `
	CREATE TABLE IF NOT EXISTS users (
		id INTEGER PRIMARY KEY AUTOINCREMENT,
		name TEXT NOT NULL,
		age INTEGER
	);`
	_, err := db.Exec(query)
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println("表创建成功或已存在")
}

3.2 删除表

如果需要删除表,可以使用以下代码:

go 复制代码
func dropTable(db *sql.DB) {
	query := "DROP TABLE IF EXISTS users;"
	_, err := db.Exec(query)
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println("表删除成功")
}

四、增删改查操作

4.1 插入数据

以下代码展示了如何向用户表中插入数据:

go 复制代码
func insertUser(db *sql.DB, name string, age int) {
	query := "INSERT INTO users (name, age) VALUES (?, ?);"
	result, err := db.Exec(query, name, age)
	if err != nil {
		log.Fatal(err)
	}
	id, _ := result.LastInsertId()
	fmt.Printf("插入成功,用户ID: %d\n", id)
}

4.2 查询数据

以下代码展示了如何查询用户表中的数据:

go 复制代码
func queryUsers(db *sql.DB) {
	query := "SELECT id, name, age FROM users;"
	rows, err := db.Query(query)
	if err != nil {
		log.Fatal(err)
	}
	defer rows.Close()
	fmt.Println("用户列表:")
	for rows.Next() {
		var id int
		var name string
		var age int
		err := rows.Scan(&id, &name, &age)
		if err != nil {
			log.Fatal(err)
		}
		fmt.Printf("ID: %d, 姓名: %s, 年龄: %d\n", id, name, age)
	}
}

4.3 更新数据

以下代码展示了如何更新用户表中的数据:

go 复制代码
func updateUser(db *sql.DB, id int, newName string, newAge int) {
	query := "UPDATE users SET name = ?, age = ? WHERE id = ?;"
	result, err := db.Exec(query, newName, newAge, id)
	if err != nil {
		log.Fatal(err)
	}
	rowsAffected, _ := result.RowsAffected()
	fmt.Printf("更新成功,影响行数: %d\n", rowsAffected)
}

4.4删除数据

以下代码展示了如何删除用户表中的数据:

go 复制代码
func deleteUser(db *sql.DB, id int) {
	query := "DELETE FROM users WHERE id = ?;"
	result, err := db.Exec(query, id)
	if err != nil {
		log.Fatal(err)
	}
	rowsAffected, _ := result.RowsAffected()
	fmt.Printf("删除成功,影响行数: %d\n", rowsAffected)
}

五、完整案例

以下是一个完整的示例,包含上述所有操作:

go 复制代码
package main
import (
	"database/sql"
	"fmt"
	"log"
	_ "github.com/mattn/go-sqlite3"
)
func main() {
	db, err := sql.Open("sqlite3", "./test.db")
	if err != nil {
		log.Fatal(err)
	}
	defer db.Close()
	err = db.Ping()
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println("成功连接到SQLite数据库")
	createTable(db)
	insertUser(db, "张三", 25)
	insertUser(db, "李四", 30)
	queryUsers(db)
	updateUser(db, 1, "张三改", 26)
	queryUsers(db)
	deleteUser(db, 2)
	queryUsers(db)
}
func createTable(db *sql.DB) {
	query := `
	CREATE TABLE IF NOT EXISTS users (
		id INTEGER PRIMARY KEY AUTOINCREMENT,
		name TEXT NOT NULL,
		age INTEGER
	);`
	_, err := db.Exec(query)
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println("表创建成功或已存在")
}
func insertUser(db *sql.DB, name string, age int) {
	query := "INSERT INTO users (name, age) VALUES (?, ?);"
	result, err := db.Exec(query, name, age)
	if err != nil {
		log.Fatal(err)
	}
	id, _ := result.LastInsertId()
	fmt.Printf("插入成功,用户ID: %d\n", id)
}
func queryUsers(db *sql.DB) {
	query := "SELECT id, name, age FROM users;"
	rows, err := db.Query(query)
	if err != nil {
		log.Fatal(err)
	}
	defer rows.Close()
	fmt.Println("用户列表:")
	for rows.Next() {
		var id int
		var name string
		var age int
		err := rows.Scan(&id, &name, &age)
		if err != nil {
			log.Fatal(err)
		}
		fmt.Printf("ID: %d, 姓名: %s, 年龄: %d\n", id, name, age)
	}
}
func updateUser(db *sql.DB, id int, newName string, newAge int) {
	query := "UPDATE users SET name = ?, age = ? WHERE id = ?;"
	result, err := db.Exec(query, newName, newAge, id)
	if err != nil {
		log.Fatal(err)
	}
	rowsAffected, _ := result.RowsAffected()
	fmt.Printf("更新成功,影响行数: %d\n", rowsAffected)
}
func deleteUser(db *sql.DB, id int) {
	query := "DELETE FROM users WHERE id = ?;"
	result, err := db.Exec(query, id)
	if err != nil {
		log.Fatal(err)
	}
	rowsAffected, _ := result.RowsAffected()
	fmt.Printf("删除成功,影响行数: %d\n", rowsAffected)
}

总结 :Go语言通过database/sqlgo-sqlite3驱动可以高效地操作SQLite数据库。上述代码涵盖了数据库连接、表操作以及增删改查的完整流程,适合作为学习Go语言操作SQLite的基础案例。

相关推荐
lecepin5 分钟前
AI Coding 资讯 2025-10-29
前端·后端·面试
Tony Bai20 分钟前
【Go模块构建与依赖管理】01 前世今生:从 GOPATH 的“混乱”到 Go Modules 的“秩序”
开发语言·后端·golang
gopyer23 分钟前
Go语言2D游戏开发入门004:零基础打造射击游戏《太空大战》3
golang·go·游戏开发
Python私教39 分钟前
从零构建 Swing 计算器:深入理解 Java GUI 开发核心机制
后端
菜鸟的迷茫42 分钟前
线程池中的坑:线程数配置不当导致任务堆积与拒绝策略失效
java·后端
缺点内向44 分钟前
Java 使用 Spire.XLS 库合并 Excel 文件实践
java·开发语言·excel
Moonbit1 小时前
MoonBit Pearls Vol.13:初探 MoonBit 中的 JavaScript 交互
javascript·后端
没逻辑1 小时前
高性能计算的利器:Rust中的SIMD实战指南
后端·rust
bcbnb1 小时前
iOS 26 描述文件管理与开发环境配置 多工具协作的实战指南
后端
Python私教1 小时前
Swing 快速入门指南:零依赖构建 Java 桌面应用
后端