Go-Sqlite3学习

go-sqlite3 是 Go 语言中用于操作 SQLite 数据库的第三方驱动库。SQLite 是一种轻量级、嵌入式的关系型数据库,适用于小型应用和嵌入式开发场景,而 go-sqlite3 库让我们能够在 Go 项目中轻松使用 SQLite 数据库。

下面是 go-sqlite3 的基本学习与使用指南:

1. 安装 go-sqlite3

要在项目中使用 go-sqlite3,首先需要安装该库。可以使用以下命令安装:

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

安装完成后,我们就可以在代码中导入它。

2. 打开和关闭数据库

在 Go 中,使用 sql 包的 sql.Open() 方法来连接数据库。go-sqlite3 实际上是一个 database/sql 驱动,所以可以直接用标准库中的 database/sql 包进行操作。

go 复制代码
package main

import (
    "database/sql"
    "log"
    _ "github.com/mattn/go-sqlite3" // 导入 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)
    }

    log.Println("数据库连接成功")
}

3. 创建表

我们可以使用 Exec 方法执行 SQL 语句,比如创建一张表:

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.Fatalf("创建表失败: %v", err)
    }
    log.Println("表创建成功")
}

4. 插入数据

使用 Exec 方法可以插入数据:

go 复制代码
func insertUser(db *sql.DB, name string, age int) {
    query := "INSERT INTO users (name, age) VALUES (?, ?)"
    _, err := db.Exec(query, name, age)
    if err != nil {
        log.Fatalf("插入数据失败: %v", err)
    }
    log.Println("数据插入成功")
}

5. 查询数据

可以使用 QueryQueryRow 方法来查询数据:

go 复制代码
func queryUsers(db *sql.DB) {
    rows, err := db.Query("SELECT id, name, age FROM users")
    if err != nil {
        log.Fatalf("查询数据失败: %v", err)
    }
    defer rows.Close()

    for rows.Next() {
        var id int
        var name string
        var age int
        err := rows.Scan(&id, &name, &age)
        if err != nil {
            log.Fatalf("数据扫描失败: %v", err)
        }
        log.Printf("用户 ID: %d, 名称: %s, 年龄: %d\n", id, name, age)
    }
}

6. 更新数据

可以使用 Exec 方法执行更新操作:

go 复制代码
func updateUser(db *sql.DB, id int, age int) {
    query := "UPDATE users SET age = ? WHERE id = ?"
    _, err := db.Exec(query, age, id)
    if err != nil {
        log.Fatalf("更新数据失败: %v", err)
    }
    log.Println("数据更新成功")
}

7. 删除数据

使用 Exec 方法可以删除数据:

go 复制代码
func deleteUser(db *sql.DB, id int) {
    query := "DELETE FROM users WHERE id = ?"
    _, err := db.Exec(query, id)
    if err != nil {
        log.Fatalf("删除数据失败: %v", err)
    }
    log.Println("数据删除成功")
}

8. 完整示例

go 复制代码
func main() {
    db, err := sql.Open("sqlite3", "./test.db")
    if err != nil {
        log.Fatal(err)
    }
    defer db.Close()

    createTable(db)
    insertUser(db, "Alice", 30)
    insertUser(db, "Bob", 25)
    queryUsers(db)
    updateUser(db, 1, 32)
    deleteUser(db, 2)
}

注意事项

  1. 数据安全 :尽量使用参数化查询(?)来防止 SQL 注入攻击。
  2. 连接管理sql.DB 连接是线程安全的,建议在全局范围内维护数据库连接。
  3. 错误处理:注意处理每个数据库操作的错误,确保数据一致性。

这样,我们就可以在 Go 中使用 go-sqlite3 驱动来操作 SQLite 数据库了。希望这对你学习 go-sqlite3 有帮助!

相关推荐
知识分享小能手1 小时前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
言之。2 小时前
Django中的软删除
数据库·django·sqlite
茯苓gao4 小时前
STM32G4 速度环开环,电流环闭环 IF模式建模
笔记·stm32·单片机·嵌入式硬件·学习
是誰萆微了承諾4 小时前
【golang学习笔记 gin 】1.2 redis 的使用
笔记·学习·golang
DKPT5 小时前
Java内存区域与内存溢出
java·开发语言·jvm·笔记·学习
aaaweiaaaaaa5 小时前
HTML和CSS学习
前端·css·学习·html
看海天一色听风起雨落6 小时前
Python学习之装饰器
开发语言·python·学习
speop7 小时前
llm的一点学习笔记
笔记·学习
非凡ghost7 小时前
FxSound:提升音频体验,让音乐更动听
前端·学习·音视频·生活·软件需求
ue星空7 小时前
月2期学习笔记
学习·游戏·ue5