婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Go語言庫系列之dotsql詳解

Go語言庫系列之dotsql詳解

熱門標(biāo)簽:濮陽自動外呼系統(tǒng)代理 長沙ai機器人電銷 澳門防封電銷卡 智能電銷機器人營銷 地圖標(biāo)注測試 賺地圖標(biāo)注的錢犯法嗎 烏魯木齊人工電銷機器人系統(tǒng) 廣東語音外呼系統(tǒng)供應(yīng)商 福州鐵通自動外呼系統(tǒng)

導(dǎo)讀:能單獨拎出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ù)打了標(biāo)記的名稱挑選語句執(zhí)行。

快速上手
準(zhǔn)備工作

目錄結(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)存當(dāng)中,所以要先安裝sqlite驅(qū)動

go get github.com/mattn/go-sqlite3

代碼演示

現(xiàn)在來寫代碼,導(dǎo)入go-sqlite3庫

import _ "github.com/mattn/go-sqlite3"

獲取sqlite3的數(shù)據(jù)庫句柄

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

加載data.sql文件

dot, _ := dotsql.LoadFromFile("data.sql")

挑選文件中的一個標(biāo)簽來執(zhí)行,Exec方法的第一個參數(shù)需要傳入句柄

dot.Exec(db, "create-users-table")

從注釋可以找到對應(yīng)的語句,是一個創(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ù),這里要注意,目前所有的操作都是基于定義的標(biāo)簽來選擇執(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類型,同學(xué)們可以自行遍歷取值測試,大功告成!

其他玩法

我們可以先預(yù)準(zhǔn)備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é)

到此這篇關(guān)于Go語言庫系列之dotsql的文章就介紹到這了,更多相關(guān)go語言庫 dotsql內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Go語言庫系列之flag的具體使用

標(biāo)簽:阿克蘇 德州 西雙版納 貴陽 慶陽 調(diào)研邀請 太原 廣西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Go語言庫系列之dotsql詳解》,本文關(guān)鍵詞  語言,庫,系列,之,dotsql,詳解,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Go語言庫系列之dotsql詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于Go語言庫系列之dotsql詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 电白县| 昌图县| 嘉兴市| 沅陵县| 平阴县| 贵阳市| 三穗县| 汾阳市| 古交市| 克东县| 无锡市| 肥乡县| 申扎县| 自治县| 华蓥市| 长子县| 安陆市| 长泰县| 吉木乃县| 武城县| 兴和县| 乃东县| 新河县| 黄陵县| 塔河县| 陈巴尔虎旗| 大方县| 青铜峡市| 南宫市| 定日县| 建昌县| 广水市| 怀集县| 江达县| 咸阳市| 栾城县| 刚察县| 梅河口市| 太湖县| 武鸣县| 新丰县|