Golang操作sqlite3数据库教程

本文介绍sqlite数据库,如何使用sqlite3包操作轻量级关系型数据库。

sqlite概述

sqlite是嵌入式关系型数据库引擎,官方描述为自包含的、无服务的、零配置并支持事务的关系型数据库引擎。我们在产品开发过程中经常使用,可以快速进行产品验证和部署,快速实现产品演示。

Go有sql包,它提供了sql(或类sql)数据库的通用接口。sql包必须与数据库驱动程序一起使用。

创建SQLITE数据库

使用sqlite3命令行工具创建数据库,查询数据。

sudo apt install sqlite3

安装好工具,创建数据库:

sqlite3 test.db
SQLite version 3.37.2 2022-01-06 13:25:41
Enter ".help" for usage hints.
sqlite> 

test.db是sqlite3命令的参数,即为数据库名称,也是磁盘上的文件名。如果文件存在就打开,不存在则创建:

sqlite> .tables
sqlite> .exit$ ls
test.db

.tables名称列出test.db数据库中所有表,当前没有表;.exit命令终止活动session命令行工具。ls命令显示当前目录下的文件,可以看到我们创建的test.db文件。

打印版本

下面示例打印sqlite3的版本,主要通过SELECT SQLITE_VERSION()语句返回版本号:

package mainimport ("database/sql""fmt""log"_ "github.com/mattn/go-sqlite3"
)func main() {db, err := sql.Open("sqlite3", ":memory:")if err != nil {log.Fatal(err)}defer db.Close()var version stringerr = db.QueryRow("SELECT SQLITE_VERSION()").Scan(&version)if err != nil {log.Fatal(err)}fmt.Println(version)
}

首先导入包,这里导入前缀为下划线,则init函数被执行。然后注册驱动;

db, err := sql.Open("sqlite3", ":memory:")

Open函数指定驱动名称和数据源名称,本示例连接内存数据库。接着调用db.Close函数,确保关闭数据库并阻止启动新的查询。

err = db.QueryRow("SELECT SQLITE_VERSION()").Scan(&version)

QueryRow执行查询,至少返回一行。Scan函数从返回行拷贝列至version变量。

$ go run main.go
3.39.4

Exec执行DML语句

Exec函数执行没有返回记录的查询语句,即DML语句:

package mainimport ("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()sts := `
DROP TABLE IF EXISTS cars;
CREATE TABLE cars(id INTEGER PRIMARY KEY, name TEXT, price INT);
INSERT INTO cars(name, price) VALUES('Audi',52642);
INSERT INTO cars(name, price) VALUES('Mercedes',57127);
INSERT INTO cars(name, price) VALUES('Skoda',9000);
INSERT INTO cars(name, price) VALUES('Volvo',29000);
INSERT INTO cars(name, price) VALUES('Bentley',350000);
INSERT INTO cars(name, price) VALUES('Citroen',21000);
INSERT INTO cars(name, price) VALUES('Hummer',41400);
INSERT INTO cars(name, price) VALUES('Volkswagen',21600);
`_, err = db.Exec(sts)if err != nil {log.Fatal(err)}fmt.Println("table cars created")
}

首先创建数据库,生成新的数据库文件:

db, err := sql.Open("sqlite3", "test.db")

接着创建表并插入数据。通过_, err = db.Exec(sts)语句执行DML。

查询记录

查询语句返回符合条件记录,典型是SELECT,可选参数为占位符:

package mainimport ("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()rows, err := db.Query("SELECT * FROM cars")if err != nil {log.Fatal(err)}defer rows.Close()for rows.Next() {var id intvar name stringvar price interr = rows.Scan(&id, &name, &price)if err != nil {log.Fatal(err)}fmt.Printf("%d %s %d\n", id, name, price)}
}

执行查询语句:

rows, err := db.Query("SELECT * FROM cars")

Next为Scan方法准备下一个结果行。成功返回True,如果没有结果或发生错误返回false。

 for rows.Next() {var id intvar name stringvar price interr = rows.Scan(&id, &name, &price)if err != nil {log.Fatal(err)}fmt.Printf("%d %s %d\n", id, name, price)}

Scan方法获取字段值,最后打印记录的列值。

带参数的prepared 语句

使用prepared 语句,可以包括占位符代替直接在语句中写值,保证数据库操作的性能和安全。

package mainimport ("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()stm, err := db.Prepare("SELECT * FROM cars WHERE id = ?")if err != nil {log.Fatal(err)}defer stm.Close()var id intvar name stringvar price intcid := 3err = stm.QueryRow(cid).Scan(&id, &name, &price)if err != nil {log.Fatal(err)}fmt.Printf("%d %s %d\n", id, name, price)
}

使用prepare函数执行prepare语句查询特定行:

stm, err := db.Prepare("SELECT * FROM cars WHERE id = ?")

传入参数给QueryRow函数,以替换占位符:

err = stm.QueryRow(cid).Scan(&id, &name, &price)

也可以一步实现上面两步功能:

row := db.QueryRow("SELECT * FROM cars WHERE id = ?", cid)

返回影响行数

RowsAffected 返回执行DML语句影响的行数:

package mainimport ("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()res, err := db.Exec("DELETE FROM cars WHERE id IN (1, 2, 3)")if err != nil {log.Fatal(err)}n, err := res.RowsAffected()if err != nil {log.Fatal(err)}fmt.Printf("The statement has affected %d rows\n", n)
}

上面示例使用delete语句删除三行记录,然后打印结果进行验证。运行结果如下:

$ go run main.go
The statement has affected 3 rows

Golang操作sqlite3数据库教程相关推荐

  1. golang操作postgresql数据库jsonb类型

    golang操作postgresql数据库jsonb类型 本文以案例为主,少言,自悟. 推荐一个测试sql的网站 SQL操作 // 创建一个带有jsonb列的表 CREATE TABLE items ...

  2. 使用PostgREST的RestAPI操作PostgreSQL数据库教程

    使用PostgREST的RestAPI操作PostgreSQL数据库教程 表和视图 公开的架构中的所有视图和表均可被查询的活动数据库角色访问,并且可供活动数据库角色访问.它们暴露在一级深度路线中.例如 ...

  3. mysql操作数据库的步骤,Golang操作MySql数据库的完整步骤记录

    前言 MySQL是业界常用的关系型数据库,在平时开发中会经常与MySql数据库打交道,所以在接下来将介绍怎么使用Go语言操作MySql数据库. 下载MySql连接驱动 Go语言中的database/s ...

  4. 封装一个自己的golang操作MySQL数据库工具

    封装一个自己的golang操作MySQL数据库工具 准备工作 导入驱动 连接mysql 增删改查 增 删 改 查 准备工作 首先我们要准备一个写golang的IDE,我用的是goland,还可以用vs ...

  5. SpringBoot 使用Phoenix操作HBase数据库教程

    SpringBoot 使用Phoenix操作HBase数据库教程 文章目录 添加 Phoenix 相关依赖 控制器实现Hbase数据库操作 好的html源码下载 文章目录 借助 Apache Phoe ...

  6. C语言操作SQLite3简明教程

    SQLite3是个非常好用的数据库,官方介绍如下, SQLite is a C-language library that implements a small, fast, self-contain ...

  7. sqlite3常用命令以及django如何操作sqlite3数据库

    一.如何进入sqlite3交互模式进行命令操作? 1.确认sqlite3是否已经安装 进去python命令行,执行 >>> import sqlite3 >>> 没 ...

  8. node sqlite 插入数据_使用 Sequelize 操作 Sqlite3 数据库

    0x01 Sequelize 是什么? Sequelize 是一个基于 Promise 的 Node.js ORM,目前支持 Postgres.MySQL.SQLite 和 Microsoft SQL ...

  9. sqlite3数据库教程

    1.sqlite3安装(命令行): sudo apt-get install sqlite3 2.图形界面查看工具安装: sudo apt-get install sqlitebrowser 3.命令 ...

最新文章

  1. vector can通信源码_CAN总线IMU在自动驾驶安全控制中的应用
  2. ecshop订单-》待付款,待发货,待收货,收货确认
  3. python斗地主游戏源码_我用tkinter写的一个斗地主练习复盘python程序
  4. 键盘输入语句||课后练习题
  5. 发现VB6中SAX的乐趣[转]
  6. php连接mysql数据库输出_PHP连接并输出数据库数据实例代码
  7. 探究 Spring 的定时任务配置
  8. Android应用开发之使用Socket进行大文件断点上传续传
  9. mysql查询交叉连接_MySQL表连接(内连接、交叉连接、外连接、联合查询)-阿里云开发者社区...
  10. SQL Server Compact 3.5 SP1 RTM发布了!
  11. 2020年中国互联网数据中心行业现状及发展趋势分析
  12. 什么是铠装光纤跳线及它的特点?
  13. JavaScript 实现网页截屏五种方法
  14. 解决user installations are disabled via policy on the machine错误
  15. W ndows7蓝屏0x00000024,Win7蓝屏代码0x00000024修复方法
  16. logo计算机编程简单指令,pc logo 基本绘图命令
  17. 关于数据库的网络存储
  18. JVM: GC过程总结(minor GC 和 Full GC)
  19. 轻量级UPF N4接口开放性技术研究与应用
  20. 关于数据挖掘中“多重共线性”的确定方法(有图有真相)

热门文章

  1. Excel 2010 VBA 入门 077 数据处理之合计汇总
  2. malloc 底层实现
  3. 远丰DRPbuilder:企业首选的分销系统
  4. Java求素组的最大值、最小值以及排序思路
  5. 【SAP-CO】成本要素的创建和成本要素组的维护
  6. Gammatone滤波器组
  7. Netsuite案例:达美乐比萨
  8. FPGA开发技巧备忘录——verilog系统函数做数学运算
  9. 阿刘全套高级风景风光摄影构图
  10. 灯布灯箱设计制作方法