導讀:能單獨拎出SQL文件的某一行或幾行執(zhí)行,是不是非常有趣?今天我們來介紹一下這個有意思的庫--dotsql。
背景介紹
dotsql不是ORM,也不是SQL查詢語句的構(gòu)建器,而是可以在一個SQL文件中拎出某幾行來執(zhí)行的工具,非常類似于ini配置文件的讀取。如果還不理解,我們來看如下內(nèi)容。
-- name: create-users-table CREATE TABLE users ( id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, name VARCHAR(255), email VARCHAR(255) ); -- name: create-user INSERT INTO users (name, email) VALUES(?, ?) -- name: find-users-by-email SELECT id,name,email FROM users WHERE email = ? -- name: find-one-user-by-email SELECT id,name,email FROM users WHERE email = ? LIMIT 1 -- name: drop-users-table DROP TABLE users
上面是SQL文件中定義的語句,我們可以很清晰地看出,每條語句上方都以 -- name 的方式打上了“注解”,而作為開發(fā)人員,可以根據(jù)打了標記的名稱挑選語句執(zhí)行。
快速上手
準備工作
目錄結(jié)構(gòu)概覽
├── data.sql
├── go.mod
├── go.sum
└── main.go
初始化項目
go mod init dotsql
創(chuàng)建data.sql文件,鍵入如下SQL,只是示例,內(nèi)容可以自定義。
-- 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) ); -- name: create-user INSERT INTO users (name, email) VALUES(?, ?) -- name: find-users-by-email SELECT id,name,email FROM users WHERE email = ? -- name: find-one-user-by-email SELECT id,name,email FROM users WHERE email = ? LIMIT 1 --name: drop-users-table DROP TABLE users
為了方便,我們用sqlite來演示,并存儲在內(nèi)存當中,所以要先安裝sqlite驅(qū)動
go get github.com/mattn/go-sqlite3
代碼演示
現(xiàn)在來寫代碼,導入go-sqlite3庫
import _ "github.com/mattn/go-sqlite3"
獲取sqlite3的數(shù)據(jù)庫句柄
db, _ := sql.Open("sqlite3", ":memory:")
加載data.sql文件
dot, _ := dotsql.LoadFromFile("data.sql")
挑選文件中的一個標簽來執(zhí)行,Exec方法的第一個參數(shù)需要傳入句柄
dot.Exec(db, "create-users-table")
從注釋可以找到對應的語句,是一個創(chuàng)建表的操作
-- 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) );
再來執(zhí)行第二條語句,插入表數(shù)據(jù)
dot.Exec(db, "create-user", "User Name", "main@example.com")
我們再來嘗試查詢表數(shù)據(jù),這里要注意,目前所有的操作都是基于定義的標簽來選擇執(zhí)行的
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語句,再在合適的時機執(zhí)行
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)
總結(jié)
到此這篇關于Go語言庫系列之dotsql的文章就介紹到這了,更多相關go語言庫 dotsql內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
標簽:阿克蘇 德州 西雙版納 貴陽 慶陽 調(diào)研邀請 太原 廣西
巨人網(wǎng)絡通訊聲明:本文標題《Go語言庫系列之dotsql詳解》,本文關鍵詞 語言,庫,系列,之,dotsql,詳解,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。