当前位置: 首页 > article >正文

Go-Sqlite3学习

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

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

1. 安装 go-sqlite3

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

go get github.com/mattn/go-sqlite3

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

2. 打开和关闭数据库

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

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 语句,比如创建一张表:

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 方法可以插入数据:

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 方法来查询数据:

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 方法执行更新操作:

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 方法可以删除数据:

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. 完整示例

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 有帮助!


http://www.kler.cn/a/379430.html

相关文章:

  • 【算法】【优选算法】双指针(下)
  • 考研要求掌握的C语言程度(插入排序)
  • qt QTabWidget详解
  • 《Keras3 深度学习初探:开启Keras3 深度学习之旅》
  • 【C++】哈希表模拟:开散列技术与哈希冲突处理
  • ELK的ElasticStack语法
  • “格格不入”的星瑞东方曜,燃油市场有麻烦了
  • 进程守护SuperVisord内部的进程定时监测并重启
  • 2024年华为OD机试真题-最小的调整次数-Python-OD统一考试(E卷)
  • locust压测工具环境搭建(Linux、Mac)
  • FBX福币交易所国际油价突然大涨!美伊针锋相对
  • json-server的使用(根据json数据一键生成接口)
  • jenkins自动化构建vue(web)项目并部署(项目实战)
  • RocketMQ可视化工具- Dashboard 使用教程 (附带可下载文件)
  • gulp入门教程14:vinyl
  • Git学习记录
  • MoonNet基准测试更新
  • springboot3项目整合Mybatis-plus启动项目报错:Invalid bean definition with name ‘xxxMapper‘
  • 基于SpringBoot+微信小程序+协同过滤算法+二维码订单位置跟踪的农产品销售平台-新
  • 一文搞懂python虚拟环境配置及使用pyenv进行python多版本管理
  • RT-Thread学习
  • 基于SSM+微信小程序的社团登录管理系统(社团1)
  • Android Studio Gradle没有assembleRelease等选项的解决方法
  • 2024快手面试算法题-生气传染
  • HTML+CSS科技感时钟(附源码!!!)
  • 浅谈vuex和pinia的区别