亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

<code id="jaf4y"><em id="jaf4y"></em></code>
  • <small id="jaf4y"><sup id="jaf4y"></sup></small>
    <big id="jaf4y"><s id="jaf4y"><table id="jaf4y"></table></s></big>
  • <code id="jaf4y"><tr id="jaf4y"></tr></code>
  • <nobr id="jaf4y"></nobr>
    <i id="jaf4y"><em id="jaf4y"><sup id="jaf4y"></sup></em></i>
  • <i id="jaf4y"><em id="jaf4y"><label id="jaf4y"></label></em></i>
    <wbr id="jaf4y"><tt id="jaf4y"></tt></wbr>
    主頁 > 知識庫 > golang實(shí)現(xiàn)mysql數(shù)據(jù)庫事務(wù)的提交與回滾

    golang實(shí)現(xiàn)mysql數(shù)據(jù)庫事務(wù)的提交與回滾

    熱門標(biāo)簽:電話機(jī)器人軟件免費(fèi) excel地圖標(biāo)注分布數(shù)據(jù) 外呼系統(tǒng)用什么卡 評價(jià)高的400電話辦理 涿州代理外呼系統(tǒng) 外呼系統(tǒng)顯本地手機(jī)號 百度地圖標(biāo)注后傳給手機(jī) 阿克蘇地圖標(biāo)注 壽光微信地圖標(biāo)注

    MySQL 事務(wù)主要用于處理操作量大,復(fù)雜度高的數(shù)據(jù)。在 MySQL 中只有使用了 Innodb 數(shù)據(jù)庫引擎的數(shù)據(jù)庫或表才支持事務(wù)。

    事務(wù)用來管理 insert,update,delete 語句,事務(wù)處理可以用來維護(hù)數(shù)據(jù)庫的完整性,保證成批的 SQL 語句要么全部執(zhí)行,要么全部不執(zhí)行。

    一般來說,事務(wù)是必須滿足4個(gè)條件(ACID)::原子性(Atomicity,或稱不可分割性)、一致性(Consistency)、隔離性(Isolation,又稱獨(dú)立性)、持久性(Durability)。

    本文主要介紹golang實(shí)現(xiàn)MySQL數(shù)據(jù)庫事物的提交與回滾

    用到的庫有:

    "github.com/jmoiron/sqlx"
    _ "github.com/go-sql-driver/mysql"

    事務(wù)(Transactions)

    事務(wù)操作是通過三個(gè)方法實(shí)現(xiàn):

    Begin():開啟事務(wù)

    Commit():提交事務(wù)(執(zhí)行sql)

    Rollback():回滾

    舉例:

    在事物里操作MySQL任意一步操作出錯(cuò),都需要Rollback()回滾。

    package main 
    import (
     "fmt"
     "github.com/alecthomas/log4go"
     _ "github.com/go-sql-driver/mysql"
     "github.com/jmoiron/sqlx"
    )
     
    var Db *sqlx.DB 
    func init()  {
     db,err:=sqlx.Open("mysql","TigerwolfC:123456@tcp(127.0.0.1:3306)/test?charset=utf8")
     if err != nil {
      fmt.Println("open mysql failed,", err)
      return
     }
     Db = db
    }
     
    func main()  {
     mysqlTest()
    } 
     
    func mysqlTest() error{
     tx, err := Db.Begin()
     if err != nil {
      log4go.Error("open mysql database fail", err)
      return err
     }
     
     result, err := tx.Exec("INSERT INTO userinfo (username, password,department,email) VALUES (?, ?,?,?)","cici","33333","it","TigerwolfC@163.com")
     if err != nil{
      fmt.Println("insert failed,error: ", err)
      tx.Rollback()
      return err
     }
     id,_ := result.LastInsertId()
     fmt.Println("insert id is :",id)
     _, err = tx.Exec("update userinfo set department = ? where username = ?","cekong","hahah")
     if err != nil{
      fmt.Println("update failed error:",err)
      tx.Rollback()
      return err
     } else {
      fmt.Println("update success!")
     }
     _, err = tx.Exec("delete from userinfo where username = ? ", "weiwei")
     if err != nil{
      fmt.Println("delete error:",err)
      tx.Rollback()
      return err
     }else{
      fmt.Println("delete success")
     }
     return tx.Commit()
    }

    當(dāng)然也可以用defer tx.Rollback(),在程序退出前回滾。

    func mysqlTest() error{
     tx, err := Db.Begin()
     if err != nil {
      log4go.Error("open mysql database fail", err)
     }
     defer tx.Rollback()
     
     result, err := tx.Exec("INSERT INTO userinfo (username, password,department,email) VALUES (?, ?,?,?)","cici","33333","it","TigerwolfC@163.com")
     if err != nil{
      fmt.Println("insert failed,error: ", err)
      return err
     }
     id,_ := result.LastInsertId()
     fmt.Println("insert id is :",id)
     _, err = tx.Exec("update userinfo set department = ? where username = ?","cekong","hahah")
     if err != nil{
      fmt.Println("update failed error:",err)
      return err
     } else {
      fmt.Println("update success!")
     }
     _, err = tx.Exec("delete from userinfo where username = ? ", "weiwei")
     if err != nil{
      fmt.Println("delete error:",err)
      return err
     }else{
      fmt.Println("delete success")
     }
     return tx.Commit()
    }

    補(bǔ)充:數(shù)據(jù)庫事務(wù)處理(go,mysql)

    看代碼吧~

    //數(shù)據(jù)庫連接池
    var db *sql.DB
    //初始化數(shù)據(jù)庫
    func initDB() (err error){
    	fmt.Println("學(xué)習(xí)數(shù)據(jù)庫")
    	dsn := "usename:password@tcp(127.0.0.1:3306)/dataname"
    	db, err = sql.Open("mysql",dsn)
    	if err!=nil {
    		fmt.Println("打開數(shù)據(jù)庫失敗 err:",err,".dsn:",dsn)
    		return
    	}
    	err = db.Ping()
    	if err!=nil {
    		fmt.Println("open failed err:",err)
    		return
    	}
    	fmt.Println("連接數(shù)據(jù)庫成功")
     
    	//最大連接數(shù)
    	db.SetMaxOpenConns(10)
    	//設(shè)置連接池中的最大閑置連接數(shù)
    	db.SetMaxIdleConns(10)
    	return
    }
     
    func trans()  {
    	tx, err := db.Begin()
    	if err!=nil {
    		fmt.Println("事務(wù)開啟失敗, err:",err)
    		return
    	}
    	sqlStr1 := "update student set age=age-2 where id=1;"
    	sqlStr2 := "update student set age=age+2 where id=3;"
    	_, err = tx.Exec(sqlStr1)
    	if err!=nil {
    		fmt.Println("修改失敗, err",err,",sqlStr1:",sqlStr1)
    		tx.Rollback()
    		return
    	}
     
    	_, err = tx.Exec(sqlStr2)
    	if err!=nil {
    		fmt.Println("修改失敗, err",err,",sqlStr2:",sqlStr2)
    		tx.Rollback()
    		return
    	}
     
    	fmt.Println("執(zhí)行成功")
    	//提交事務(wù)
    	tx.Commit()
    }
    func main() {
    	fmt.Println("mysql 002.事務(wù)處理")
    	initDB()
    	trans() 
    }

    以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

    您可能感興趣的文章:
    • mysql創(chuàng)建表添加字段注釋的實(shí)現(xiàn)方法
    • MySQL之存儲過程按月創(chuàng)建表的方法步驟
    • mysql創(chuàng)建表的sql語句詳細(xì)總結(jié)
    • Hibernate4在MySQL5.1以上版本創(chuàng)建表出錯(cuò) type=InnDB
    • 詳解在MySQL中創(chuàng)建表的教程
    • MySQL動態(tài)創(chuàng)建表,數(shù)據(jù)分表的存儲過程
    • MYSQL建立外鍵失敗幾種情況記錄Can''t create table不能創(chuàng)建表
    • IDEA連接mysql數(shù)據(jù)庫報(bào)錯(cuò)的解決方法
    • django將圖片保存到mysql數(shù)據(jù)庫并展示在前端頁面的實(shí)現(xiàn)
    • MySQL安裝后默認(rèn)自帶數(shù)據(jù)庫的作用詳解
    • python3 實(shí)現(xiàn)mysql數(shù)據(jù)庫連接池的示例代碼
    • mysql數(shù)據(jù)庫入門第一步之創(chuàng)建表

    標(biāo)簽:重慶 梅河口 欽州 蘭州 銅川 汕頭 吐魯番 雞西

    巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《golang實(shí)現(xiàn)mysql數(shù)據(jù)庫事務(wù)的提交與回滾》,本文關(guān)鍵詞  golang,實(shí)現(xiàn),mysql,數(shù)據(jù)庫,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《golang實(shí)現(xiàn)mysql數(shù)據(jù)庫事務(wù)的提交與回滾》相關(guān)的同類信息!
  • 本頁收集關(guān)于golang實(shí)現(xiàn)mysql數(shù)據(jù)庫事務(wù)的提交與回滾的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    免费国产在线视频| 日韩女人做爰大片| 日本特黄特色aa大片免费| 在线观看成人网 | 日韩中文字幕在线观看视频| 国产麻豆精品视频| 99色视频在线| 午夜在线观看视频免费 成人| 免费国产在线视频| 亚洲精品中文字幕久久久久久| 欧美激情一区二区三区在线播放| 午夜激情视频在线观看| 一级女性全黄久久生活片| 欧美激情一区二区三区视频高清| 国产91丝袜在线播放0| 免费毛片播放| 欧美激情伊人| 国产一级生活片| 麻豆系列国产剧在线观看| 99久久精品费精品国产一区二区| 日韩中文字幕在线观看视频| 日韩在线观看免费完整版视频| 免费的黄视频| 日本特黄特黄aaaaa大片| 久久99中文字幕| 天堂网中文字幕| 成人影视在线播放| 久久久久久久免费视频| 午夜家庭影院| 国产网站免费在线观看| 一级片片| 中文字幕一区二区三区 精品| 精品国产一区二区三区久久久狼 | 久久精品成人一区二区三区| 国产一区二区精品| 久久久久久久网| 黄视频网站免费| 香蕉视频三级| 亚洲精品影院| 国产极品白嫩美女在线观看看| 亚洲 国产精品 日韩| 午夜激情视频在线观看| 精品国产一区二区三区久久久狼 | 国产伦精品一区三区视频 | 黄视频网站免费| 国产极品精频在线观看| 欧美1区| 999精品视频在线| 精品久久久久久中文字幕一区| 美女免费毛片| 精品毛片视频| 天天色色网| 国产伦精品一区二区三区在线观看| 精品视频在线观看免费| 91麻豆国产福利精品| 精品毛片视频| 日韩av片免费播放| 精品久久久久久免费影院| 四虎影视库| 欧美日本免费| 台湾毛片| 香蕉视频三级| 久草免费在线视频| 国产成人啪精品视频免费软件| 国产一区二区高清视频| 日本在线www| 成人免费一级纶理片| 人人干人人草| 91麻豆精品国产片在线观看| 日韩一级黄色片| 国产伦精品一区二区三区在线观看| 精品视频一区二区三区免费| 九九久久99综合一区二区| 色综合久久久久综合体桃花网| 午夜在线观看视频免费 成人| 天天色成人| 999久久久免费精品国产牛牛| 欧美大片一区| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 天天做人人爱夜夜爽2020毛片| 日韩在线观看免费完整版视频| 国产高清在线精品一区二区 | 人人干人人草| 国产亚洲精品成人a在线| 中文字幕Aⅴ资源网| 中文字幕Aⅴ资源网| 免费国产在线视频| 黄色免费三级| 天天做日日爱夜夜爽| 久久精品成人一区二区三区| 香蕉视频三级| 欧美电影免费| 日本伦理网站| 久久国产精品自线拍免费| 91麻豆精品国产自产在线观看一区| 国产成人精品一区二区视频| 一级片片| 999精品视频在线| 99热精品在线| 中文字幕一区二区三区 精品| 亚洲精品中文字幕久久久久久| 日韩中文字幕一区二区不卡| 欧美激情一区二区三区在线播放| 精品视频在线观看一区二区| 91麻豆精品国产自产在线观看一区| 黄色免费三级| 免费一级生活片| 国产视频一区二区在线播放| 九九九在线视频| 国产精品12| 免费国产在线视频| 亚洲第一视频在线播放| 国产伦精品一区二区三区在线观看| 一级毛片视频免费| 午夜欧美成人久久久久久| 成人高清视频在线观看| 久久99中文字幕| 免费国产在线观看| 成人免费观看视频| 国产视频在线免费观看| 97视频免费在线观看| 青青青草影院 | 亚洲第一视频在线播放| 青青青草影院 | 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 精品视频在线看 | 午夜家庭影院| 黄视频网站在线免费观看| 精品在线观看一区| 成人免费观看视频| 免费一级生活片| 国产国产人免费视频成69堂| 可以免费在线看黄的网站| 99久久精品国产高清一区二区| 国产综合91天堂亚洲国产| 国产高清在线精品一区二区 | 麻豆午夜视频| 日韩中文字幕在线观看视频| 欧美一区二区三区性| 亚洲精品影院一区二区| 成人高清免费| 亚洲精品中文字幕久久久久久| 欧美一区二区三区性| 国产一区二区精品久久91| 亚洲精品久久玖玖玖玖| 天天做人人爱夜夜爽2020毛片| 亚洲第一视频在线播放| 国产高清在线精品一区二区 | 国产精品自拍在线观看| 999精品视频在线| 久久精品店| 午夜欧美成人久久久久久| 国产a免费观看| 日韩免费片| 日韩欧美一及在线播放| 一本伊大人香蕉高清在线观看| 99色吧| 精品毛片视频| 亚洲不卡一区二区三区在线 | 久久精品免视看国产成人2021| 国产不卡在线观看| 亚洲天堂一区二区三区四区| 日本免费看视频| 亚飞与亚基在线观看| 九九干| 精品国产香蕉在线播出 | 可以免费在线看黄的网站| 久久国产影视免费精品| 一级毛片视频免费| 四虎影视库| 国产一区二区高清视频| 91麻豆国产福利精品| 日本特黄特黄aaaaa大片| 色综合久久天天综合绕观看| 欧美日本国产| 日韩专区在线播放| 国产伦精品一区三区视频 | 久久精品免视看国产成人2021| 91麻豆国产福利精品| 精品国产一区二区三区久久久狼 | 国产伦精品一区三区视频 | 韩国三级香港三级日本三级| 日韩一级黄色| 国产国语在线播放视频| 久久精品店| 免费国产在线视频| 韩国毛片免费大片| 99久久网站| 中文字幕一区二区三区 精品| 国产一区精品| 99久久网站| 午夜欧美成人久久久久久| 韩国毛片免费大片| 久久精品店| 天天做人人爱夜夜爽2020毛片| 日本特黄特黄aaaaa大片| 九九干| 天天色成人| 国产网站免费在线观看| 国产高清在线精品一区a|