现在来写代码,导入go-sqlite3库
import _ "github.com/mattn/go-sqlite3"
获取sqlite3的数据库句柄
db, _ := sql.Open("sqlite3", ":memory:")
加载data.sql文件
dot, _ := dotsql.LoadFromFile("data.sql")
挑选文件中的一个标签来执行,Exec方法的第一个参数需要传入句柄
dot.Exec(db, "create-users-table")
从注释可以找到对应的语句,是一个创建表的操作
-- name: create-users-table DROP TABLE IF EXISTS users; CREATE TABLE users ( id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, name VARCHAR(255), email VARCHAR(255) );
再来执行第二条语句,插入表数据
dot.Exec(db, "create-user", "User Name", "main@example.com")
我们再来尝试查询表数据,这里要注意,目前所有的操作都是基于定义的标签来选择执行的
rows, _ := dot.Query(db, "find-users-by-email", "main@example.com") var ( id int name string email string ) for rows.Next() { rows.Scan(&id, &name, &email) fmt.Println(id, name, email) }
Query方法返回的是*sql.Rows类型,同学们可以自行遍历取值测试,大功告成!
其他玩法
我们可以先预准备SQL语句,再在合适的时机执行
stmt, err := dot.Prepare(db, "drop-users-table") result, err := stmt.Exec()
同样,我们也可以将多个SQL文件合并再进行取值操作
dot1, err := dotsql.LoadFromFile("queries1.sql") dot2, err := dotsql.LoadFromFile("queries2.sql") dot := dotsql.Merge(dot1, dot2)
总结
到此这篇关于Go语言库系列之dotsql的文章就介绍到这了,更多相关go语言库 dotsql内容请搜索
标签:SQLite
相关阅读 >>
android 中自定义contentprovider与contentobserver的使用简单实例
scp远程vps快速搬家和wdcp升级php5.3安装memcached和eaccelerator教程
更多相关阅读请进入《Sqlite》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。