精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Golang如何優雅連接MySQL數據庫?

數據庫 MySQL
Go原生就支持連接數據庫,所以在使用 Golang 開發時,當需要數據庫交互時,即可使用database/sql包。

 Go原生就支持連接數據庫,所以在使用 Golang 開發時,當需要數據庫交互時,即可使用database/sql包。


在Go中訪問DB需用sql.DB接口:可創建語句(statement)和事務(transaction),執行查詢,獲取結果。

使用DB時,除database/sql包,還需引入想使用的特定DB驅動。官方不提供實現,需要先下載三方實現,點擊這里查看各種各樣的實現版本。

通常DB選型MySQL,所以選型驅動為:github.com/go-sql-driver/mysql,需引入包:

"database/sql"_ "github.com/go-sql-driver/mysql"

 包名前的"_" 

import 下劃線(如:import _ github/demo)的作用:當導入一個包時,該包下的文件里所有init()函數都會被執行,然而,有些時候我們并不需要把整個包都導入進來,僅僅是是希望它執行init()函數而已。這個時候就可以使用 import _ 引用該包。

上面的MySQL驅動中引入的就是MySQL包中各個init()方法,你無法通過包名來調用包中的其他函數。導入時,驅動的初始化函數會調用sql.Register將自己注冊在database/sql包的全局變量sql.drivers中,以便以后通過sql.Open訪問。

 案例用數據表

 初始化數據庫連接[[353659]] 

 sql.Open()中的數據庫連接串格式為:"用戶名:密碼@tcp(IP:端口)/數據庫?charset=utf8"。DB的類型為:*sql.DB,有DB后即可執行CRUD。

Go將數據庫操作分為兩類:Query與Exec

  • Query表示查詢,它會從數據庫獲取查詢結果(一系列行,可能為空)。
  • Exec表示執行語句,它不會返回行。

常見數據庫操作模式:

  • QueryRow只返回一行的查詢,作為Query的一個常見特例。
  • Prepare準備一個需要多次使用的語句,供后續執行用。

查詢操作

  1. var user User 
  2. rows, e := DB.Query("select * from user where id in (1,2,3)"
  3. if e == nil { 
  4.     errors.New("query incur error"
  5. for rows.Next(){ 
  6.     e := rows.Scan(user.sex, user.phone, user.nameuser.id,  
  7.       user.age) 
  8.     if e != nil{ 
  9.         fmt.Println(json.Marshal(user)) 
  10.     } 
  11. rows.Close() 
  12. // 單行查詢操作 
  13. DB.QueryRow("select * from user where id=1").Scan(user.age,  
  14.   user.id, user.nameuser.phone, user.sex) 

執行流程 

  1. 使用db.Query()來發送查詢到數據庫,獲取結果集Rows,并檢查錯誤。
  2. 使用rows.Next()作為循環條件,迭代讀取結果集。
  3. 使用rows.Scan從結果集中獲取一行結果。
  4. 使用rows.Err()在退出迭代后檢查錯誤。
  5. 使用rows.Close()關閉結果集,釋放連接。

增刪改和Exec

通常不會約束你查詢必須用Query,只是Query會返回結果集,而Exec不會返回。所以如果你執行的是增刪改操作一般用Exec會好一些。Exec返回的結果是Result,Result接口允許獲取執行結果的元數據:

  1. type Result interface { 
  2.     // 用于返回自增ID,并不是所有的關系型數據庫都有這個功能。 
  3.     LastInsertId() (int64, error) 
  4.     // 返回受影響的行數。 
  5.     RowsAffected() (int64, error) 

 準備查詢

如果你現在想使用占位符的功能,where 的條件想以參數的形式傳入,Go提供了db.Prepare語句來幫你綁定。準備查詢的結果是一個準備好的語句(prepared statement),語句中可以包含執行時所需參數的占位符(即綁定值)。準備查詢比拼字符串的方式好很多,它可以轉義參數,避免SQL注入。同時,準備查詢對于一些數據庫也省去了解析和生成執行計劃的開銷,有利于性能。

占位符

PostgreSQL使用$N作為占位符,N是一個從1開始遞增的整數,代表參數的位置,方便參數的重復使用。MySQL使用?作為占位符,SQLite兩種占位符都可以,而Oracle則使用:param1的形式。

  1. MySQL               PostgreSQL            Oracle 
  2. =====               ==========            ====== 
  3. WHERE col = ?       WHERE col = $1        WHERE col = :col 
  4. VALUES(?, ?, ?)     VALUES($1, $2, $3)    VALUES(:val1, :val2, :val3) 
  5. stmt, e := DB.Prepare("select * from user where id=?"
  6. query, e := stmt.Query(1) 
  7. query.Scan() 

 事務的使用

通過db.Begin()來開啟一個事務,Begin方法會返回一個事務對象Tx。在結果變量Tx上調用Commit()或者Rollback()方法會提交或回滾變更,并關閉事務。在底層,Tx會從連接池中獲得一個連接并在事務過程中保持對它的獨占。事務對象Tx上的方法與數據庫對象sql.DB的方法一一對應,例如Query,Exec等。事務對象也可以準備(prepare)查詢,由事務創建的準備語句會顯式綁定到創建它的事務。

  1. //開啟事務 
  2. tx, err := DB.Begin() 
  3. if err != nil { 
  4.     fmt.Println("tx fail"
  5. //準備sql語句 
  6. stmt, err := tx.Prepare("DELETE FROM user WHERE id = ?"
  7. if err != nil { 
  8.     fmt.Println("Prepare fail"
  9.     return false 
  10. //設置參數以及執行sql語句 
  11. res, err := stmt.Exec(user.id) 
  12. if err != nil { 
  13.     fmt.Println("Exec fail"
  14.     return false 
  15. //提交事務 
  16. tx.Commit() 
  17.  
  18. 我們來一個完整的sql操作:package main 
  19.  
  20. import ( 
  21.     "database/sql" 
  22.     "encoding/json" 
  23.     "fmt" 
  24.     _ "github.com/go-sql-driver/mysql" 
  25.     "github.com/pkg/errors" 
  26.     "strings" 
  27.  
  28. //數據庫配置 
  29. const ( 
  30.     userName = "root" 
  31.     password = "123456" 
  32.     ip       = "127.0.0.1" 
  33.     port     = "3306" 
  34.     dbName   = "test" 
  35.  
  36. //Db數據庫連接池 
  37. var DB *sql.DB 
  38.  
  39. type User struct { 
  40.     id    int64 
  41.     name  string 
  42.     age   int8 
  43.     sex   int8 
  44.     phone string 
  45.  
  46. //注意方法名大寫,就是public 
  47. func InitDB() { 
  48.     //構建連接:"用戶名:密碼@tcp(IP:端口)/數據庫?charset=utf8" 
  49.     path := strings.Join([]string{userName, ":"password"@tcp(", ip, ":", port, ")/", dbName, "?charset=utf8"}, ""
  50.     //打開數據庫,前者是驅動名,所以要導入:_ "github.com/go-sql-driver/mysql" 
  51.     DB, _ = sql.Open("mysql", path) 
  52.     //設置數據庫最大連接數 
  53.     DB.SetConnMaxLifetime(100) 
  54.     //設置上數據庫最大閑置連接數 
  55.     DB.SetMaxIdleConns(10) 
  56.     //驗證連接 
  57.     if err := DB.Ping(); err != nil { 
  58.         fmt.Println("open database fail"
  59.         return 
  60.     } 
  61.     fmt.Println("connnect success"
  62.  
  63. //查詢操作 
  64. func Query() { 
  65.     var user User 
  66.     rows, e := DB.Query("select * from user where id in (1,2,3)"
  67.     if e == nil { 
  68.         errors.New("query incur error"
  69.     } 
  70.     for rows.Next() { 
  71.         e := rows.Scan(user.sex, user.phone, user.nameuser.id, user.age) 
  72.         if e != nil { 
  73.             fmt.Println(json.Marshal(user)) 
  74.         } 
  75.     } 
  76.     rows.Close() 
  77.     DB.QueryRow("select * from user where id=1").Scan(user.age, user.id, user.nameuser.phone, user.sex) 
  78.  
  79.     stmt, e := DB.Prepare("select * from user where id=?"
  80.     query, e := stmt.Query(1) 
  81.     query.Scan() 
  82.  
  83. func DeleteUser(user User) bool { 
  84.     //開啟事務 
  85.     tx, err := DB.Begin() 
  86.     if err != nil { 
  87.         fmt.Println("tx fail"
  88.     } 
  89.     //準備sql語句 
  90.     stmt, err := tx.Prepare("DELETE FROM user WHERE id = ?"
  91.     if err != nil { 
  92.         fmt.Println("Prepare fail"
  93.         return false 
  94.     } 
  95.     //設置參數以及執行sql語句 
  96.     res, err := stmt.Exec(user.id) 
  97.     if err != nil { 
  98.         fmt.Println("Exec fail"
  99.         return false 
  100.     } 
  101.     //提交事務 
  102.     tx.Commit() 
  103.     //獲得上一個insert的id 
  104.     fmt.Println(res.LastInsertId()) 
  105.     return true 
  106.  
  107. func InsertUser(user User) bool { 
  108.     //開啟事務 
  109.     tx, err := DB.Begin() 
  110.     if err != nil { 
  111.         fmt.Println("tx fail"
  112.         return false 
  113.     } 
  114.     //準備sql語句 
  115.     stmt, err := tx.Prepare("INSERT INTO user (`name`, `phone`) VALUES (?, ?)"
  116.     if err != nil { 
  117.         fmt.Println("Prepare fail"
  118.         return false 
  119.     } 
  120.     //將參數傳遞到sql語句中并且執行 
  121.     res, err := stmt.Exec(user.nameuser.phone) 
  122.     if err != nil { 
  123.         fmt.Println("Exec fail"
  124.         return false 
  125.     } 
  126.     //將事務提交 
  127.     tx.Commit() 
  128.     //獲得上一個插入自增的id 
  129.     fmt.Println(res.LastInsertId()) 
  130.     return true 
  131.  
  132. func main() { 
  133.     InitDB() 
  134.     Query() 
  135.     defer DB.Close() 

參考

https://www.cnblogs.com/rickiyang/p/11074180.html

 

責任編輯:姜華 來源: JavaEdge
相關推薦

2010-05-14 11:12:16

連接MySql

2009-11-24 16:48:15

PHP mysqli

2021-08-02 10:53:28

PythonMySQL數據庫

2017-09-11 19:30:44

MySQLCmd命令連接數據庫

2009-06-01 09:57:43

netbeans連接數netbeans數據庫netbeans連接m

2009-07-07 14:56:33

JSP連接MySQL

2018-02-26 20:00:00

編程語言JavaMySQL

2020-09-22 15:56:31

Java

2011-05-26 13:42:50

MFC連接MySql數據庫

2011-07-27 13:58:48

EclipseMySQL

2024-08-19 11:45:18

2017-11-27 11:41:06

python數據庫數據分析

2024-01-02 08:47:42

2023-08-29 07:35:15

2010-06-07 15:24:34

Java連接MYSQL

2024-12-04 16:12:31

2011-07-05 10:16:16

Qt 數據庫 SQLite

2011-04-01 12:32:37

aspaccess數據庫

2015-10-30 14:00:33

adosybaseodbc

2024-05-28 00:00:30

Golang數據庫
點贊
收藏

51CTO技術棧公眾號

欧美午夜精品理论片| 欧美国产综合视频| 国产一级大片在线观看| 日韩极品在线| 在线观看91视频| 中文字幕中文字幕99| 亚洲欧美另类综合| 久久综合亚州| 欧美成人亚洲成人日韩成人| 国产高清成人久久| 电影一区电影二区| 亚洲精品久久嫩草网站秘色| 精品产品国产在线不卡| 日韩av免费播放| 欧美日韩少妇| 国产一区二区三区久久精品 | 国内揄拍国内精品久久| 日韩国产中文字幕| 99中文字幕在线| 成人爽a毛片免费啪啪| 日韩毛片精品高清免费| 狼狼综合久久久久综合网| 亚洲视频一区二区三区四区| 亚洲黄色大片| 美女扒开尿口让男人操亚洲视频网站| 18禁裸乳无遮挡啪啪无码免费| 中文字幕成人| 色婷婷亚洲综合| 免费特级黄色片| 男人资源在线播放| 91啪亚洲精品| 成人av播放| 亚洲熟女乱色一区二区三区久久久| 99精品久久| 欧美精品日韩三级| 国产在线免费av| 国产精品一区高清| 精品粉嫩超白一线天av| 九九久久久久久| 色猫猫成人app| 欧美体内谢she精2性欧美| 成人免费在线视频播放| 久久久久久久久免费视频| 久久久久久毛片| 久久久水蜜桃| 日韩在线观看视频一区二区三区| 国产一区二区三区香蕉| 91精品美女在线| 一二区在线观看| 欧美aa在线视频| 国产a∨精品一区二区三区不卡| 四虎成人精品永久免费av| 亚洲精品国产首次亮相| 啊v视频在线一区二区三区| 国产一二三四区在线| 曰本一区二区三区视频| 亚洲乱码国产乱码精品精天堂| 亚洲自拍偷拍精品| 乱亲女h秽乱长久久久| 亚洲第一级黄色片| 看全色黄大色黄女片18| 国产精品xxxav免费视频| 亚洲爱爱爱爱爱| 中国特级黄色大片| 国产主播性色av福利精品一区| 精品日韩在线一区| 免费看黄色片的网站| 97久久亚洲| 日韩精品久久久久久福利| 西西大胆午夜视频| 国产传媒欧美日韩成人精品大片| 国产亚洲成精品久久| 老司机福利在线观看| 久久美女视频| 欧美人与性动交a欧美精品| 九九热视频精品| 日韩视频精品在线观看| 国产成人高清激情视频在线观看| 天天天天天天天干| 国产一区二区精品在线观看| 高清不卡一区二区三区| 手机亚洲第一页| 国产精品久久久一区麻豆最新章节| 亚洲图片欧洲图片日韩av| 日本暖暖在线视频| 亚洲自拍与偷拍| 久久久噜噜噜www成人网| 狠狠久久伊人中文字幕| 日韩精品影音先锋| 精品夜夜澡人妻无码av| 国产精品久久久久无码av| 欧美福利视频网站| 亚洲图片在线视频| 精品一区二区三区在线视频| 高清国产一区| 国产在线黄色| 中文字幕亚洲在| 给我免费播放片在线观看| 日韩欧美精品一区二区三区| 色欧美乱欧美15图片| 色婷婷成人在线| 亚洲2区在线| 亚洲免费高清视频| 黄色录像免费观看| 在线观看视频日韩| 国产精品久久久久久av| 精品国产乱码一区二区三| 成人a区在线观看| 欧美在线激情| 午夜羞羞小视频在线观看| 五月婷婷欧美视频| 天堂av在线网站| 一本一道久久a久久| 日韩精品免费视频| 精品一区二区三孕妇视频| 一本久道久久综合狠狠爱| 国产精品中文字幕在线| 粉嫩av一区二区夜夜嗨| 国产日韩欧美在线一区| www.国产二区| 亚洲第一二三四区| 日韩限制级电影在线观看| www国产视频| 欧美色蜜桃97| 91精品国产自产91精品| 97人妻人人澡人人爽人人精品| 本田岬高潮一区二区三区| 色一情一区二区三区四区 | 六月婷婷综合| 欧美一区二区在线免费播放| 最近中文字幕在线mv视频在线 | 久久综合色综合| 麻豆一区二区在线| 久久婷婷国产综合尤物精品| 国产黄色在线观看| 91国产福利在线| 国产黑丝一区二区| 99久精品视频在线观看视频| 国产成人小视频在线观看| 亚洲国产精彩视频| 亚洲色图在线播放| 丰满少妇在线观看| 亚欧日韩另类中文欧美| 欧美国产日韩免费| 亚洲成人久久精品| 亚洲欧美偷拍另类a∨色屁股| 能在线观看的av网站| 大奶在线精品| 色综合久久悠悠| 国产精品久久久久久久免费看| 久久精品亚洲一区二区三区浴池| 日本a在线天堂| 国产精品久一| 日韩有码片在线观看| av毛片在线免费观看| 91麻豆国产精品久久| 99在线精品免费视频| 97久久综合区小说区图片区| 中文字幕亚洲欧美| 在线观看av大片| 欧美国产精品专区| 亚洲视频在线a| 思热99re视热频这里只精品| 国产91精品高潮白浆喷水| 色婷婷中文字幕| 午夜精品一区在线观看| 亚洲午夜久久久久久久久| 国产一区二区三区自拍| aa日韩免费精品视频一| 在线黄色网页| 日韩精品一区二区三区swag| 欧美成人免费观看视频| 国产精品一区二区免费不卡| 国产日韩亚洲欧美在线| 高潮久久久久久久久久久久久久| 欧美—级a级欧美特级ar全黄| 日韩欧美国产二区| 国产三级伦理在线| 精品粉嫩超白一线天av| 福利一区二区三区四区| 91麻豆成人久久精品二区三区| 男人插女人视频在线观看| 国内精品麻豆美女在线播放视频| 9.1国产丝袜在线观看| 神马久久高清| 欧美专区在线观看一区| 久久久久久成人网| 国产乱人伦偷精品视频不卡| 久久久久久久久久伊人| 色哟哟精品丝袜一区二区| 国产极品精品在线观看| 日韩av中文| 日韩免费电影网站| 日本高清www免费视频| 久久精品一区二区三区四区| 日韩精品视频一二三| 欧美 日韩 国产精品免费观看| 国产精品国产三级欧美二区| 厕沟全景美女厕沟精品| xxxx欧美18另类的高清| 天天操天天干天天干| 欧美日韩中文字幕一区| 欧美黑人精品一区二区不卡| 91欧美一区二区| 狠狠操狠狠干视频| 欧美亚韩一区| 国产一区二区在线观看免费播放| 日本午夜免费一区二区| 久久久久免费视频| 国产在线超碰| 欧美精品一区二区三区四区| 中文字幕第三页| 午夜久久久久久久久| 少妇av片在线观看| 国产东北露脸精品视频| 成年人在线看片| 今天的高清视频免费播放成人| 茄子视频成人在线观看| 好吊妞国产欧美日韩免费观看网站 | 68精品久久久久久欧美| 最新真实国产在线视频| 亚洲精品久久久久国产| 亚洲天堂视频网| 欧美日韩亚洲国产一区| 中文字幕手机在线观看| 国产欧美日韩在线视频| 国产精品扒开腿做爽爽爽a片唱戏| 青青草国产成人99久久| 国产婷婷一区二区三区| 婷婷综合在线| 日韩在线三区| 思热99re视热频这里只精品| av一本久道久久波多野结衣| 日韩一区二区三免费高清在线观看| 91精品国产九九九久久久亚洲| 一区二区三区伦理| xxx成人少妇69| 激情小视频在线| 亚洲国产欧美一区二区三区久久| 亚洲精品无码久久久久| 欧美日韩免费一区| 久操免费在线视频| 亚洲视频香蕉人妖| 日本污视频网站| 国产亚洲欧洲997久久综合| 大乳护士喂奶hd| 成人性视频免费网站| 日本美女久久久| 日韩成人伦理电影在线观看| 黄色片一级视频| 亚洲深爱激情| 精品久久久久久久久久中文字幕| 亚洲小说区图片区| 69精品丰满人妻无码视频a片| 日韩欧美一区二区三区在线视频| 日产精品一线二线三线芒果| 国产精品亚洲人成在99www| 欧美福利精品| 日本不卡免费一区| 视频一区视频二区视频| 日韩高清欧美| 亚洲最新免费视频| 国产精品久久久久久久免费观看| 亚洲黄色网址在线观看| 亚洲国产精品成人| 视色,视色影院,视色影库,视色网| 欧美国产偷国产精品三区| 亚洲一区二区不卡视频| 天天综合网网欲色| 蜜臀av.com| 欧美久久综合| 久无码久无码av无码| 久久精品综合| 自拍偷拍 国产| 日本女优在线视频一区二区 | 羞羞答答国产精品www一本| 激情综合网婷婷| 蜜桃在线一区二区三区| 五月天婷婷亚洲| 国产在线不卡一区| 国产91在线免费观看| 92精品国产成人观看免费| 最新中文字幕视频| 欧美国产乱子伦| 国产又黄又爽又无遮挡| 亚洲一二三四久久| 波多野结衣一区二区三区在线 | 中国精品一区二区| 在线成人小视频| 欧美亚洲精品在线观看| 亚洲欧美日韩精品| 欧美性天天影视| 欧美多人乱p欧美4p久久| 182tv在线播放| 欧美一区亚洲一区| 成人亚洲网站| 97久久天天综合色天天综合色hd | 国产一区在线免费观看| 性欧美lx╳lx╳| 正在播放亚洲| 99re国产精品| 在线观看亚洲色图| 99久久99久久免费精品蜜臀| 永久免费av无码网站性色av| 日韩美女久久久| 看片网址国产福利av中文字幕| 欧美视频在线播放| 性生活三级视频| 亚洲丝袜一区在线| 亚洲小说区图片区都市| 青青草成人在线| 欧美第一在线视频| 日韩精品av一区二区三区| 国产一区清纯| 一区二区成人网| 99久久精品免费看国产| 能直接看的av| 色老头久久综合| 精品国产av一区二区三区| 国产午夜精品久久久| 91麻豆免费在线视频| 国产不卡在线观看| 免费看久久久| 91大学生片黄在线观看| 日本欧美一区二区三区乱码| 国产一级伦理片| 亚洲国产欧美在线| 99国产成人精品| 中文字幕亚洲一区二区三区| 国模精品视频| 国产在线一区二区三区欧美| 亚洲女同中文字幕| 青青青在线视频免费观看| av不卡免费在线观看| 国产一区二区三区精品在线| 欧美性高潮床叫视频| 亚洲AV无码国产精品午夜字幕| 在线免费看av不卡| 综合日韩av| 欧美高清一区二区| 日韩亚洲在线| 少妇熟女视频一区二区三区| 亚洲欧洲成人av每日更新| 日韩精品一区不卡| 日韩成人av网址| 9765激情中文在线| 国产精品二区在线观看| 欧美88av| 丰满少妇xbxb毛片日本| 玉米视频成人免费看| 国产日韩在线观看一区| www.日韩免费| 高清久久一区| 欧美与动交zoz0z| 经典一区二区三区| 久久国产柳州莫菁门| 欧美日韩一本到| av中文字幕在线| 国产精品极品美女在线观看免费| 免费看成人吃奶视频在线| 哪个网站能看毛片| 91在线精品秘密一区二区| 久久久久久91亚洲精品中文字幕| 日韩一区二区不卡| 高清电影在线观看免费| 91免费版网站入口| 亚洲情侣在线| 国产人成视频在线观看| 亚洲成人在线免费| 天堂网2014av| 欧美在线视频一区二区| 欧美自拍偷拍| 国模私拍视频在线观看| 中文字幕亚洲不卡| 性欧美一区二区三区| 97成人在线视频| 九一精品国产| 亚洲免费看av| 亚洲美女在线国产| 全色精品综合影院| 国产成人精品日本亚洲| av资源久久| www.夜夜爽| 亚洲高清久久久| 青草久久伊人| 国产精品免费久久久| 在线精品国产| 91精品人妻一区二区三区四区| 性久久久久久久久| 欧洲亚洲精品视频| 国产精品久久久久av| 亚洲午夜91| 爱爱免费小视频| 欧美日韩精品电影| 丝袜在线观看| 日韩精品福利视频| 国产成人啪午夜精品网站男同| 久久午夜鲁丝片午夜精品| 亚洲香蕉在线观看| 欧美久久亚洲|