时间:2021-05-22
导读:能单独拎出SQL文件的某一行或几行执行,是不是非常有趣?今天我们来介绍一下这个有意思的库--dotsql。
背景介绍
dotsql不是ORM,也不是SQL查询语句的构建器,而是可以在一个SQL文件中拎出某几行来执行的工具,非常类似于ini配置文件的读取。如果还不理解,我们来看如下内容。
-- name: create-users-tableCREATE TABLE users ( id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, name VARCHAR(255), email VARCHAR(255));-- name: create-userINSERT INTO users (name, email) VALUES(?, ?)-- name: find-users-by-emailSELECT id,name,email FROM users WHERE email = ?-- name: find-one-user-by-emailSELECT id,name,email FROM users WHERE email = ? LIMIT 1-- name: drop-users-tableDROP TABLE users上面是SQL文件中定义的语句,我们可以很清晰地看出,每条语句上方都以 -- name 的方式打上了“注解”,而作为开发人员,可以根据打了标记的名称挑选语句执行。
快速上手
准备工作
目录结构概览
├── data.sql
├── go.mod
├── go.sum
└── main.go
初始化项目
go mod init dotsql
创建data.sql文件,键入如下SQL,只是示例,内容可以自定义。
-- name: create-users-tableDROP TABLE IF EXISTS users;CREATE TABLE users ( id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, name VARCHAR(255), email VARCHAR(255));-- name: create-userINSERT INTO users (name, email) VALUES(?, ?)-- name: find-users-by-emailSELECT id,name,email FROM users WHERE email = ?-- name: find-one-user-by-emailSELECT id,name,email FROM users WHERE email = ? LIMIT 1--name: drop-users-tableDROP TABLE users为了方便,我们用sqlite来演示,并存储在内存当中,所以要先安装sqlite驱动
go get github.com/mattn/go-sqlite3
代码演示
现在来写代码,导入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-tableDROP 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内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言Go语言作为编程语言中的后起之秀,在博采众长的同时又不失个性,在注重运行效率的同时又重视开发效率,不失为一种好的开发语言。在go语言中,没有类的概念,但是仍
bootstraptable系列:JS表格组件神器bootstraptable详解(基础版)JS组件系列之Bootstraptable表格组件神器【终结篇】JS
问题简介Go语言是一个简单却蕴含深意的语言,大家都知道go语言标准库汇总内置了对json文件的处理,非常方便,最近在写一个应用的时候,需要从json文件中载入配
psutil是一个跨平台进程和系统监控的Python库,而gopsutil是其Go语言版本的实现。本文介绍了它的基本使用。Go语言部署简单、性能好的特点非常适合
一.GO语言开发包1.什么是GO语言开发包go语言开发包其实是对go语言的一种实现,包括相应版本的语法,编译,运行,垃圾回收等,里面包含着开发go语言所需的标准