<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      Go語言庫系列之dotsql

      導讀:能單獨拎出SQL文件的某一行或幾行執行,是不是非常有趣?今天我們來介紹一下這個有意思的庫--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語言與技術原理。
      關注我

      posted @ 2020-04-02 15:16  MARIOOW  閱讀(672)  評論(0)    收藏  舉報
      主站蜘蛛池模板: aaa少妇高潮大片免费看| 亚洲成年av天堂动漫网站| 国产永久免费高清在线观看| 99re6在线视频精品免费下载| 久久精品国产一区二区三| 亚洲av无码乱码在线观看野外 | 韩国av无码| 人妻丝袜AV中文系列先锋影音| 激情综合网五月激情五月| 久久婷婷大香萑太香蕉AV人| 欧美成人aaa片一区国产精品| 国产成人综合久久亚洲精品| 成人无码精品1区2区3区免费看| 九九热在线视频观看最新| 国产精品区一区第一页| 2021亚洲爆乳无码专区| 日本污视频在线观看| 在线日韩日本国产亚洲| 日本亚洲一区二区精品| 蜜臀精品视频一区二区三区| 亚洲国产综合精品 在线 一区| 99在线国内在线视频22| 国产精品成人自产拍在线| 国产va免费精品观看| 亚洲欧美在线一区中文字幕| 日韩本精品一区二区三区| 94人妻少妇偷人精品| av综合亚洲一区二区| 亚洲欧美日韩在线码| 亚洲高潮喷水无码AV电影| 国产精品人伦一区二区三| 国产91特黄特色A级毛片| 青草99在线免费观看| 亚洲老熟女一区二区三区| 曰批免费视频播放免费| 欧美亚洲日本国产其他| 欧美成人精品手机在线| 滦平县| 狠狠躁夜夜躁无码中文字幕 | 宣化县| 婷婷综合缴情亚洲|