在golang中操作mysql數(shù)據(jù)庫(kù)的實(shí)現(xiàn)代碼
前言
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ù)連接的打開(kāi)和關(guān)閉操作.
•sql.DB 為我們管理數(shù)據(jù)庫(kù)連接池
需要注意的是,sql.DB表示操作數(shù)據(jù)庫(kù)的抽象訪問(wèn)接口,而非一個(gè)數(shù)據(jù)庫(kù)連接對(duì)象;它可以根據(jù)driver打開(kāi)關(guān)閉數(shù)據(jù)庫(kù)連接,管理連接池。正在使用的連接被標(biāo)記為繁忙,用完后回到連接池等待下次使用。所以,如果你沒(méi)有把連接釋放回連接池,會(huì)導(dǎo)致過(guò)多連接使系統(tǒng)資源耗盡。
Golang操作mysql簡(jiǎn)介
Golang操作mysql數(shù)據(jù)庫(kù)的感覺(jué)有點(diǎn)想php中的pdo對(duì)mysql操作,假設(shè)你原本是phper轉(zhuǎn)型到golang中的接受起來(lái)很親切,總體的感覺(jué)非常簡(jiǎn)單
Golang操作mysql的注意點(diǎn)
golang實(shí)現(xiàn)了對(duì)mysql操作的標(biāo)準(zhǔn)庫(kù)然而卻沒(méi)有實(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的感覺(jué) ,如上代碼實(shí)際上也可以不編寫(xiě)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ǎng)站的支持!
相關(guān)文章
MySQL數(shù)據(jù)庫(kù)索引的弊端及合理使用
索引可以說(shuō)是數(shù)據(jù)庫(kù)中的一個(gè)大心臟了,如果說(shuō)一個(gè)數(shù)據(jù)庫(kù)少了索引,那么數(shù)據(jù)庫(kù)本身存在的意義就不大了,和普通的文件沒(méi)什么兩樣,本文從細(xì)節(jié)和實(shí)際業(yè)務(wù)的角度看看在MySQL中B+樹(shù)索引好處2021-11-11將MySQL數(shù)據(jù)庫(kù)移植為PostgreSQL
PostgreSQL 作為功能最強(qiáng)勁的開(kāi)源 OO 數(shù)據(jù)庫(kù),仿佛一直不為國(guó)內(nèi)用戶所熟識(shí)。而我個(gè)人也僅是因?yàn)楣ぷ鞯木壒式佑|到這款超經(jīng)典的數(shù)據(jù)庫(kù),并深為之折服。2009-07-07pycharm2017實(shí)現(xiàn)python3.6與mysql的連接
這篇文章主要為大家詳細(xì)介紹了PyCharm連接MySQL數(shù)據(jù)庫(kù)的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-03-03SQL?Group?By分組后如何選取每組最新的一條數(shù)據(jù)
經(jīng)常在分組查詢之后,需要的是分組的某行數(shù)據(jù),例如更新時(shí)間最新的一條數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于SQL?Group?By分組后如何選取每組最新的一條數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2022-10-10mysql VARCHAR的最大長(zhǎng)度到底是多少
今天群里有人問(wèn)varchar 不是最大應(yīng)該只可以設(shè)置65532(第一個(gè)字節(jié)+兩個(gè)長(zhǎng)度字節(jié))嗎 ,但是為什么可以設(shè)置成655332012-10-10