国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫(kù)技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫(kù) - Mysql - 在golang中操作mysql數(shù)據(jù)庫(kù)的實(shí)現(xiàn)代碼

在golang中操作mysql數(shù)據(jù)庫(kù)的實(shí)現(xiàn)代碼

2019-06-27 15:12JimPang Mysql

這篇文章主要介紹了在golang中操作mysql數(shù)據(jù)庫(kù)的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

前言

Golang 提供了database/sql包用于對(duì)SQL數(shù)據(jù)庫(kù)的訪問(wèn), 作為操作數(shù)據(jù)庫(kù)的入口對(duì)象sql.DB, 主要為我們提供了兩個(gè)重要的功能:

•sql.DB 通過(guò)數(shù)據(jù)庫(kù)驅(qū)動(dòng)為我們提供管理底層數(shù)據(jù)庫(kù)連接的打開和關(guān)閉操作.

•sql.DB 為我們管理數(shù)據(jù)庫(kù)連接池

需要注意的是,sql.DB表示操作數(shù)據(jù)庫(kù)的抽象訪問(wèn)接口,而非一個(gè)數(shù)據(jù)庫(kù)連接對(duì)象;它可以根據(jù)driver打開關(guān)閉數(shù)據(jù)庫(kù)連接,管理連接池。正在使用的連接被標(biāo)記為繁忙,用完后回到連接池等待下次使用。所以,如果你沒有把連接釋放回連接池,會(huì)導(dǎo)致過(guò)多連接使系統(tǒng)資源耗盡。

Golang操作mysql簡(jiǎn)介

Golang操作mysql數(shù)據(jù)庫(kù)的感覺有點(diǎn)想php中的pdo對(duì)mysql操作,假設(shè)你原本是phper轉(zhuǎn)型到golang中的接受起來(lái)很親切,總體的感覺非常簡(jiǎn)單

Golang操作mysql的注意點(diǎn)

golang實(shí)現(xiàn)了對(duì)mysql操作的標(biāo)準(zhǔn)庫(kù)然而卻沒有實(shí)現(xiàn)mysql的驅(qū)動(dòng)

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

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

在test數(shù)據(jù)庫(kù)中建立表字段如下所示

CREATE TABLE IF NOT EXISTS `test`.`user` (
 `user_id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '用戶編號(hào)',
 `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 = '用戶表'

實(shí)現(xiàn)對(duì)數(shù)據(jù)的增(insert)操作

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

如上代碼有一種操作php中pdo的感覺 ,如上代碼實(shí)際上也可以不編寫Prepare方法直接通過(guò)Stmt實(shí)例的Exec方法直接實(shí)現(xiàn)

總結(jié)

以上所述是小編給大家介紹的在golang中操作mysql數(shù)據(jù)庫(kù)的實(shí)現(xiàn)代碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)服務(wù)器之家網(wǎng)站的支持!

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 午夜伦理电影 | 精品国产乱码久久久久久影片 | av天天网| 一道本一二三区 | 亚洲国产成人精品久久久国产成人一区 | 亚洲欧美精品 | 一级做a爰片性色毛片2021 | 午夜家庭影院 | 大尺度av在线 | 久久人人爽人人爽 | 成人av观看| 一区二区在线视频 | 久久成人一区二区 | 国产大片在线观看 | 日韩在线免费观看视频 | 欧美日本精品 | 久久久国产一区二区三区 | 国产三级一区 | 欧美在线观看一区 | 国产欧美日韩综合精品一区二区 | 老牛嫩草一区二区三区眼镜 | 在线色综合 | 国产精品视频一区二区三区不卡 | 国产精品成人观看视频国产奇米 | 天天操人人干 | 成人a视频 | 久久亚洲欧美日韩精品专区 | 国产精品日本 | 久久国产精品无码网站 | 欧美久久久精品 | 91精品久久久久久久久 | 99精品欧美一区二区三区综合在线 | 99精品久久 | 免费视频一区二区 | 青娱乐国产视频 | 国产人久久人人人人爽 | 免费一区二区三区 | 欧美一级片在线播放 | 色视频在线播放 | 免费黄色在线观看 | 午夜午夜精品一区二区三区文 |