濮阳杆衣贸易有限公司

主頁 > 知識庫 > 在golang中操作mysql數(shù)據(jù)庫的實現(xiàn)代碼

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

熱門標簽:400電話辦理都選易號網(wǎng) 湘潭電銷機器人咨詢電話 外呼系統(tǒng)防封號違法嗎 寶應(yīng)電信400電話辦理費用 高德地圖標注中心個人注冊 外呼系統(tǒng)服務(wù) 高德地圖標注模式 如何在高德地圖標注新地址 電銷機器人針對的

前言

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

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

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

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

Golang操作mysql簡介

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

Golang操作mysql的注意點

golang實現(xiàn)了對mysql操作的標準庫然而卻沒有實現(xiàn)mysql的驅(qū)動

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

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

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

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 = '用戶表'

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

package main
import (
 "fmt"
 "database/sql"
 //導(dǎo)入mysql的驅(qū)動
 _ "github.com/go-sql-driver/mysql" 
)
func main(){
 //使用database/sql包中的Open連接數(shù)據(jù)庫
 db,err := sql.Open("mysql","root:root@tcp(localhost:3306)/test?charset=utf8")
 if err != nil {
 fmt.Println("連接數(shù)據(jù)庫失敗:",err)
 return 
 }
 //使用DB結(jié)構(gòu)體實例方法Prepare預(yù)處理插入,Prepare會返回一個stmt對象
 stmt,err := db.Prepare("insert into `user`(user_name,user_age,user_sex)values(?,?,?)")
 if err!=nil{
 fmt.Println("預(yù)處理失敗:",err)
 return  
 }
 //使用Stmt對象執(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的感覺 ,如上代碼實際上也可以不編寫Prepare方法直接通過Stmt實例的Exec方法直接實現(xiàn)

總結(jié)

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

您可能感興趣的文章:
  • Golang操作MySql數(shù)據(jù)庫的完整步驟記錄
  • 如何利用Golang解析讀取Mysql備份文件
  • Golang中如何對MySQL進行操作詳解
  • golang gorm 操作mysql及gorm基本用法
  • golang實現(xiàn)mysql數(shù)據(jù)庫備份的操作方法
  • golang中連接mysql數(shù)據(jù)庫

標簽:黃山 宿遷 南充 賀州 馬鞍山 蘭州 佛山 黔南

巨人網(wǎng)絡(luò)通訊聲明:本文標題《在golang中操作mysql數(shù)據(jù)庫的實現(xiàn)代碼》,本文關(guān)鍵詞  在,golang,中,操作,mysql,數(shù)據(jù)庫,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《在golang中操作mysql數(shù)據(jù)庫的實現(xiàn)代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于在golang中操作mysql數(shù)據(jù)庫的實現(xiàn)代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    抚顺市| 巢湖市| 林西县| 颍上县| 商城县| 涪陵区| 天柱县| 襄樊市| 南宁市| 三门峡市| 平罗县| 岢岚县| 临潭县| 石首市| 丹东市| 榆林市| 高青县| 开江县| 滦南县| 繁峙县| 长岛县| 新竹市| 平阴县| 鄱阳县| 普安县| 彩票| 北辰区| 临漳县| 尼勒克县| 女性| 棋牌| 江口县| 垦利县| 元氏县| 邵阳市| 蕉岭县| 株洲县| 张家川| 同江市| 普格县| 班玛县|