一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - 在golang中操作mysql數據庫的實現代碼

在golang中操作mysql數據庫的實現代碼

2019-06-27 15:12JimPang Mysql

這篇文章主要介紹了在golang中操作mysql數據庫的實現代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

前言

Golang 提供了database/sql包用于對SQL數據庫的訪問, 作為操作數據庫的入口對象sql.DB, 主要為我們提供了兩個重要的功能:

•sql.DB 通過數據庫驅動為我們提供管理底層數據庫連接的打開和關閉操作.

•sql.DB 為我們管理數據庫連接池

需要注意的是,sql.DB表示操作數據庫的抽象訪問接口,而非一個數據庫連接對象;它可以根據driver打開關閉數據庫連接,管理連接池。正在使用的連接被標記為繁忙,用完后回到連接池等待下次使用。所以,如果你沒有把連接釋放回連接池,會導致過多連接使系統資源耗盡。

Golang操作mysql簡介

Golang操作mysql數據庫的感覺有點想php中的pdo對mysql操作,假設你原本是phper轉型到golang中的接受起來很親切,總體的感覺非常簡單

Golang操作mysql的注意點

golang實現了對mysql操作的標準庫然而卻沒有實現mysql的驅動

因此我們需要先從github中下載go-sql-driver這個驅動包(建議在src目錄下執行),使用命令如下所示:

go get github.com/go-sql-driver/mysql

在test數據庫中建立表字段如下所示

CREATE TABLE IF NOT EXISTS `test`.`user` (
 `user_id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '用戶編號',
 `user_name` VARCHAR(45) NOT NULL COMMENT '用戶名稱',
 `user_age` TINYINT(3) UNSIGNED NOT NULL DEFAULT 0 COMMENT '用戶年齡',
 `user_sex` TINYINT(3) UNSIGNED NOT NULL DEFAULT 0 COMMENT '用戶性別',
 PRIMARY KEY (`user_id`))
 ENGINE = InnoDB
 AUTO_INCREMENT = 1
 DEFAULT CHARACTER SET = utf8
 COLLATE = utf8_general_ci
 COMMENT = '用戶表'

實現對數據的增(insert)操作

package main
import (
 "fmt"
 "database/sql"
 //導入mysql的驅動
 _ "github.com/go-sql-driver/mysql" 
)
func main(){
 //使用database/sql包中的Open連接數據庫
 db,err := sql.Open("mysql","root:root@tcp(localhost:3306)/test?charset=utf8")
 if err != nil {
 fmt.Println("連接數據庫失敗:",err)
 return 
 }
 //使用DB結構體實例方法Prepare預處理插入,Prepare會返回一個stmt對象
 stmt,err := db.Prepare("insert into `user`(user_name,user_age,user_sex)values(?,?,?)")
 if err!=nil{
 fmt.Println("預處理失敗:",err)
 return  
 }
 //使用Stmt對象執行預處理參數
 result,err := stmt.Exec("pengjin",33,"男")
 if err!=nil{
 fmt.Println("執行預處理失敗:",err)
 return  
 }else{
 rows,_ := result.RowsAffected()
 fmt.Println("執行成功,影響行數",rows,"行" )
 }
}

如上代碼有一種操作php中pdo的感覺 ,如上代碼實際上也可以不編寫Prepare方法直接通過Stmt實例的Exec方法直接實現

總結

以上所述是小編給大家介紹的在golang中操作mysql數據庫的實現代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲一级特黄特黄的大片 | 国产福利一区二区精品视频 | 四虎精品成人免费影视 | 亚洲 欧美 偷自乱 图片 | 99久久精品无码一区二区毛片 | 国产播放啪视频免费视频 | 日韩精品中文字幕久久 | 四虎影院入口 | 日本人作爰啪啪全过程 | 男女拍拍拍免费视频网站 | 国产大片网站 | 亚洲国产欧美另类va在线观看 | 欧美一级专区免费大片 | 亚洲免费视 | 成人免费观看在线视频 | 亚欧毛片基地国产毛片基地 | 国产精品久久久久久网站 | 免费在线观看成年人视频 | 全肉一女n男np高h乳 | 成年人免费观看视频网站 | 色先锋影音先锋 | 亚洲视频在线观看免费视频 | 免费视频专区一国产盗摄 | 日韩精品一区二区三区老鸭窝 | 欧美日韩精品一区二区三区视频在线 | 青青草原国产在线 | 草莓秋葵菠萝蜜绿巨人污 | 精品综合在线 | 久热这里只有精品99国产6 | 精品国产理论在线观看不卡 | 日本欧美大码a在线视频播放 | 久久久免费观成人影院 | 99精品视频在线观看re | 亚洲乱人伦在线 | 国产chinese男男gaygay | 999热在线精品观看全部 | 成人福利视频网址 | 羞羞视频免费观看网站 | 九色PORNY真实丨国产大胸 | heyzo1754北岛玲在线视频 | 国内自拍网红在线综合 |