91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Go的dotsql是什么

發布時間:2021-03-11 17:05:04 來源:億速云 閱讀:133 作者:TREX 欄目:編程語言

這篇文章主要介紹“Go的dotsql是什么”,在日常操作中,相信很多人在Go的dotsql是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Go的dotsql是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

背景介紹

dotsql不是ORM,也不是SQL查詢語句的構建器,而是可以在一個SQL文件中拎出某幾行來執行的工具,非常類似于ini配置文件的讀取。如果還不理解,我們來看如下內容。

-- 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 的方式打上了“注解”,而作為開發人員,可以根據打了標記的名稱挑選語句執行。

快速上手
準備工作

目錄結構概覽

├── data.sql
├── go.mod
├── go.sum
└── main.go

初始化項目

go mod init dotsql

創建data.sql文件,鍵入如下SQL,只是示例,內容可以自定義。

-- 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來演示,并存儲在內存當中,所以要先安裝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-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是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

治多县| 安康市| 门头沟区| 乌鲁木齐市| 溧水县| 伊金霍洛旗| 阳高县| 雷山县| 松原市| 云安县| 玉龙| 大连市| 大港区| 班戈县| 乐亭县| 延长县| 舟曲县| 大兴区| 东明县| 临武县| 白玉县| 郴州市| 永定县| 壤塘县| 昌乐县| 峨眉山市| 中山市| 崇仁县| 英德市| 鹤岗市| 丁青县| 亳州市| 安平县| 留坝县| 寻乌县| 巴林右旗| 涞水县| 揭东县| 赞皇县| 定陶县| 新营市|