0

0

Golang项目实战:基于SQLite的联系人管理器_基础数据库操作

P粉602998670

P粉602998670

发布时间:2026-02-19 16:12:10

|

536人浏览过

|

来源于php中文网

原创

用 database/sql 而非 mattn/go-sqlite3 裸 api,导入驱动后 sql.open 初始化,建表加 if not exists,设 pragma journal_mode = wal,增删改用 exec 配 lastinsertid,单行查用 queryrow,批量插入用多值语句,时间存 unix 时间戳,事务用 defer 判断 nil 和提交状态确保回滚安全。

golang项目实战:基于sqlite的联系人管理器_基础数据库操作

SQLite 在 Go 里用 database/sql 就够了,别碰 mattn/go-sqlite3 的裸 API

Go 官方 database/sql 接口抽象得足够好,SQLite 驱动(mattn/go-sqlite3)只是个后端实现。直接调用它的 sqlite3.Open 或手写 C. 相关逻辑,反而绕开连接池、事务封装和上下文取消支持,后续加并发或超时会踩坑。

常见错误现象:panic: runtime error: invalid memory address,往往源于手动管理 *sqlite3.SQLiteConn 后忘了 Close,或在多 goroutine 中复用非线程安全的裸连接。

  • 初始化只做两件事:导入驱动 _ "github.com/mattn/go-sqlite3",再用 sql.Open("sqlite3", "contacts.db")
  • 建表语句必须带 IF NOT EXISTS,否则每次重启程序都可能报 table contacts already exists
  • PRAGMA journal_mode = WAL 建议在 Open 后立刻执行一次,提升并发读写性能,但注意它不支持内存数据库(:memory:

ExecQueryRow 别混用:增删改用 Exec,单行查用 QueryRow

新手常把 INSERT 之后接 QueryRow,以为能拿到自增 ID —— 实际上 QueryRow 会尝试解析结果集,而 INSERT 没有返回列,导致 Scansql: no rows in result set 或静默失败。

正确姿势是:用 Exec 执行增删改,再调 Result.LastInsertId() 拿 ID;单行查询(如按 ID 查联系人)才用 QueryRow

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

迷你天猫商城
迷你天猫商城

迷你天猫商城是一个基于Spring Boot的综合性B2C电商平台,需求设计主要参考天猫商城的购物流程:用户从注册开始,到完成登录,浏览商品,加入购物车,进行下单,确认收货,评价等一系列操作。 作为迷你天猫商城的核心组成部分之一,天猫数据管理后台包含商品管理,订单管理,类别管理,用户管理和交易额统计等模块,实现了对整个商城的一站式管理和维护。所有页面均兼容IE10及以上现代浏览器。部署方式1、项目

下载
  • INSERT INTO contacts (name, phone) VALUES (?, ?)db.Exec(...)lastID, _ := res.LastInsertId()
  • SELECT name, phone FROM contacts WHERE id = ?db.QueryRow(...).Scan(&name, &phone)
  • 批量插入别用循环多次 Exec,改用参数化多值语句:INSERT INTO contacts VALUES (?,?),(?,?),(?,?),最多一次塞 500 行,避免参数超限(SQLite 默认 999)

时间字段存 INTEGER(Unix 时间戳),别存 TEXTDATETIME

SQLite 本身没有原生日期类型,DATETIME 是文本模拟,排序、范围查询(如“最近 7 天”)会出错:字符串比较 "2024-10-01" "2024-9-30" 成立,但逻辑上不成立。

INTEGERtime.Now().Unix(),查的时候转回 time.Unix(ts, 0),简单可靠。

  • 建表写 created_at INTEGER NOT NULL,不是 DATETIME DEFAULT CURRENT_TIMESTAMP
  • WHERE 条件写 created_at >= ?,参数传 sevenDaysAgo.Unix(),别拼字符串
  • 如果必须导出可读时间,用 strftime('%Y-%m-%d %H:%M', created_at, 'unixepoch') 在 SQL 层转换,而不是在 Go 里反复 time.Unix(...).Format(...)

事务没 Commit 就退出?用 defer tx.Rollback() + 显式 Commit 配合

Go 的 defer 看似方便,但写成 defer tx.Rollback() 然后在成功路径里忘掉 tx.Commit(),会导致每次操作都回滚 —— 表面无报错,数据就是不落盘,极难排查。

真正安全的写法是:先 defer func() 匿名函数,在里面判断 tx 是否为 nil 且未提交,再决定是否回滚。

  • 标准模板:
    tx, err := db.Begin()
    if err != nil {
        return err
    }
    defer func() {
        if tx != nil {
            tx.Rollback()
        }
    }()
    // ... 操作
    if err := tx.Commit(); err == nil {
        tx = nil // 标记已提交
    }
  • 不要依赖 recover() 捕获 panic 后自动回滚 —— SQLite 驱动不保证 panic 时连接状态干净
  • 事务内避免调用外部 HTTP 或阻塞 I/O,超时会导致锁表,其他查询被卡住

最麻烦的从来不是语法,而是事务中途 panic 了但没触发 defer,或者 tx.Commit() 返回 error 却被忽略 —— 这时候日志里只有 database is locked,得翻调用栈看哪条语句没 finish。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

207

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

238

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

348

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

212

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

403

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

344

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

197

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

970

2025.06.17

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

660

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 5.3万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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