第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

Go語(yǔ)言庫(kù)系列之dotsql

標(biāo)簽:
Go

导读:能单独拎出SQL文件的某些行或几行执行,是不是非常有趣?今天我们来介绍一下这个有意思的库–dotsql。

背景介绍

dotsql不是ORM,也不是SQL查询语句的生成器,或者可以在一个SQL文件中拎出某几行来执行的工具,非常地ini配置文件的读取。如果还不理解,我们来看如下内容。

SQL-名称:创建用户表CREATE TABLE用户(ID整数主键自动递增非空,名称VARCHAR(255),电子邮件VARCHAR(255));-名称:创建用户INSERT INTO用户(名称,电子邮件)VALUES (?,?)-名称:通过电子邮件查找用户SELECT ID,名称

,,,,,,,,,,,,,,,,,,,,,从用户那里发送电子邮件,其中电子邮件=?

-名称:通过电子邮件查找一个用户SELECT ID,名称,来​​自用户的电子邮件,其中电子邮件=?限制1

-名称:拖放式的用户表DROP TABLE用户 是SQL文件中定义的语句,我们可以很清晰地研磨,每条语句上方都以 -name ‘的方式打上了’注解’,而作为开发人员,可以根据打了标记的名称选择语句执行。###快速上手###准备工作目录结构概述”shell。├──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 。合并( dot1 , dot2 )```


點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺(jué)得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫(xiě)下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶(hù)
支付方式
打開(kāi)微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專(zhuān)欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消