分享
  1. 首页
  2. 文章

Go语言中使用SQLite数据库

songxingzhu · · 18437 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

Go语言中使用SQLite数据库

1、驱动

Go支持sqlite的驱动也比较多,但是好多都是不支持database/sql接口的

目前支持database/sql的SQLite数据库驱动只有第一个,我目前也是采用它来开发项目的。采用标准接口有利于以后出现更好的驱动的时候做迁移。

2、实例代码

示例的数据库表结构如下所示,相应的建表SQL:

CREATE TABLE `userinfo` (
 `uid` INTEGER PRIMARY KEY AUTOINCREMENT,
 `username` VARCHAR(64) NULL,
 `departname` VARCHAR(64) NULL,
 `created` DATE NULL
);
CREATE TABLE `userdeatail` (
 `uid` INT(10) NULL,
 `intro` TEXT NULL,
 `profile` TEXT NULL,
 PRIMARY KEY (`uid`)
);

看下面Go程序是如何操作数据库表数据:增删改查

package main
import (
 "database/sql"
 "fmt"
 _ "github.com/mattn/go-sqlite3"
)
func main() {
 db, err := sql.Open("sqlite3", "./foo.db")
 checkErr(err)
 //插入数据
 stmt, err := db.Prepare("INSERT INTO userinfo(username, departname, created) values(?,?,?)")
 checkErr(err)
 res, err := stmt.Exec("astaxie", "研发部门", "2012年12月09日")
 checkErr(err)
 id, err := res.LastInsertId()
 checkErr(err)
 fmt.Println(id)
 //更新数据
 stmt, err = db.Prepare("update userinfo set username=? where uid=?")
 checkErr(err)
 res, err = stmt.Exec("astaxieupdate", id)
 checkErr(err)
 affect, err := res.RowsAffected()
 checkErr(err)
 fmt.Println(affect)
 //查询数据
 rows, err := db.Query("SELECT * FROM userinfo")
 checkErr(err)
 for rows.Next() {
 var uid int
 var username string
 var department string
 var created string
 err = rows.Scan(&uid, &username, &department, &created)
 checkErr(err)
 fmt.Println(uid)
 fmt.Println(username)
 fmt.Println(department)
 fmt.Println(created)
 }
 //删除数据
 stmt, err = db.Prepare("delete from userinfo where uid=?")
 checkErr(err)
 res, err = stmt.Exec(id)
 checkErr(err)
 affect, err = res.RowsAffected()
 checkErr(err)
 fmt.Println(affect)
 db.Close()
}
func checkErr(err error) {
 if err != nil {
 panic(err)
 }
}

我们可以看到上面的代码和MySQL例子里面的代码几乎是一模一样的,唯一改变的就是导入的驱动改变了,然后调用sql.Open是采用了SQLite的方式打开。


有疑问加站长微信联系(非本文作者)

本文来自:博客园

感谢作者:songxingzhu

查看原文:Go语言中使用SQLite数据库

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
18437 次点击
1 回复 | 直到 2020年12月28日 16:28:06
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏