這篇文章主要介紹“Go的dotsql是什么”,在日常操作中,相信很多人在Go的dotsql是什么問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”Go的dotsql是什么”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
成都創(chuàng)新互聯(lián)成立10年來(lái),這條路我們正越走越好,積累了技術(shù)與客戶(hù)資源,形成了良好的口碑。為客戶(hù)提供成都網(wǎng)站建設(shè)、成都網(wǎng)站制作、網(wǎng)站策劃、網(wǎng)頁(yè)設(shè)計(jì)、空間域名、網(wǎng)絡(luò)營(yíng)銷(xiāo)、VI設(shè)計(jì)、網(wǎng)站改版、漏洞修補(bǔ)等服務(wù)。網(wǎng)站是否美觀、功能強(qiáng)大、用戶(hù)體驗(yàn)好、性?xún)r(jià)比高、打開(kāi)快等等,這些對(duì)于網(wǎng)站建設(shè)都非常重要,成都創(chuàng)新互聯(lián)通過(guò)對(duì)建站技術(shù)性的掌握、對(duì)創(chuàng)意設(shè)計(jì)的研究為客戶(hù)提供一站式互聯(lián)網(wǎng)解決方案,攜手廣大客戶(hù),共同發(fā)展進(jìn)步。
背景介紹
dotsql不是ORM,也不是SQL查詢(xún)語(yǔ)句的構(gòu)建器,而是可以在一個(gè)SQL文件中拎出某幾行來(lái)執(zhí)行的工具,非常類(lèi)似于ini配置文件的讀取。如果還不理解,我們來(lái)看如下內(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文件中定義的語(yǔ)句,我們可以很清晰地看出,每條語(yǔ)句上方都以 -- name 的方式打上了“注解”,而作為開(kāi)發(fā)人員,可以根據(jù)打了標(biāo)記的名稱(chēng)挑選語(yǔ)句執(zhí)行。
快速上手
準(zhǔn)備工作
目錄結(jié)構(gòu)概覽
├── data.sql
├── go.mod
├── go.sum
└── main.go
初始化項(xiàng)目
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來(lái)演示,并存儲(chǔ)在內(nèi)存當(dāng)中,所以要先安裝sqlite驅(qū)動(dòng)
go get github.com/mattn/go-sqlite3
代碼演示
現(xiàn)在來(lái)寫(xiě)代碼,導(dǎo)入go-sqlite3庫(kù)
import _ "github.com/mattn/go-sqlite3"
獲取sqlite3的數(shù)據(jù)庫(kù)句柄
db, _ := sql.Open("sqlite3", ":memory:")
加載data.sql文件
dot, _ := dotsql.LoadFromFile("data.sql")
挑選文件中的一個(gè)標(biāo)簽來(lái)執(zhí)行,Exec方法的第一個(gè)參數(shù)需要傳入句柄
dot.Exec(db, "create-users-table")
從注釋可以找到對(duì)應(yīng)的語(yǔ)句,是一個(gè)創(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) );
再來(lái)執(zhí)行第二條語(yǔ)句,插入表數(shù)據(jù)
dot.Exec(db, "create-user", "User Name", "main@example.com")
我們?cè)賮?lái)嘗試查詢(xún)表數(shù)據(jù),這里要注意,目前所有的操作都是基于定義的標(biāo)簽來(lái)選擇執(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類(lèi)型,同學(xué)們可以自行遍歷取值測(cè)試,大功告成!
其他玩法
我們可以先預(yù)準(zhǔn)備SQL語(yǔ)句,再在合適的時(shí)機(jī)執(zhí)行
stmt, err := dot.Prepare(db, "drop-users-table") result, err := stmt.Exec()
同樣,我們也可以將多個(gè)SQL文件合并再進(jìn)行取值操作
dot1, err := dotsql.LoadFromFile("queries1.sql") dot2, err := dotsql.LoadFromFile("queries2.sql") dot := dotsql.Merge(dot1, dot2)
總結(jié)
到此,關(guān)于“Go的dotsql是什么”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!
文章標(biāo)題:Go的dotsql是什么
URL地址:http://chinadenli.net/article44/gojihe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、網(wǎng)站策劃、ChatGPT、網(wǎng)站內(nèi)鏈、靜態(tài)網(wǎng)站、網(wǎng)站維護(hù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)