真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

go操作mysql數(shù)據(jù)庫的方法介紹

這篇文章主要為大家詳細(xì)介紹了go操作MySQL數(shù)據(jù)庫的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。

專注于為中小企業(yè)提供網(wǎng)站制作、網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)竹山免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了上1000+企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

Go(又稱Golang)是Google開發(fā)的一種靜態(tài)強(qiáng)類型、編譯型、并發(fā)型,并具有垃圾回收功能的編程語言。下面就來由go入門教程欄目介紹一些關(guān)于mysql的操作。

go操作mysql數(shù)據(jù)庫的方法介紹

go操作mysql數(shù)據(jù)庫,用的庫是 go-sql-driver/mysql,安裝直接go get

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

sql.DB

DB類型可用的函數(shù)有:

1、Query(c string, args interface{} …) (*Rows, error),常用于SELECT語句

2、Exec(c string, args interface{} …) (*Rows, error),常用與UPDATE和INSERT

3、Prepare(c string) (*Stmt, error),其他語句,也可以用于執(zhí)行上述語句,返回Stmt指針

sql.Stmt

Stmt是準(zhǔn)備好的語句,可以執(zhí)行數(shù)據(jù)庫語句操作,常用函數(shù)有:

Exec(args interface{} …) (Result, error),給定參數(shù)并執(zhí)行準(zhǔn)備好的語句,然后返回語句的總結(jié)果

//...
	stmt, err := db.Perpare("INSERT INTO User(user,pwd) VALUES (?, ?)")
	if err != nil {
		panic(err)
	}
	defer stmt.Close()
	_, err := stmt.Exec("laoli", "123456")
	if err != nil {
		panic(err)
	}
//...
//...
	stmt, err := db.Perpare("DELETE FROM User")
	if err != nil {
		panic(err)
	}
	defer stmt.Close()
	_, err := stmt.Exec()
	if err != nil {
		panic(err)
	}

Query(args interface{} …) (*Rows, error),給定參數(shù)并執(zhí)行準(zhǔn)備好的語句,返回行結(jié)果,比方說SELECT操作就必須用這個(gè)函數(shù)調(diào)用。

sql.Rows

Rows是sql語句執(zhí)行返回的表,Rows會(huì)占用緩存,Rows.Next()里,如果返回false,則會(huì)自動(dòng)釋放緩存。
看一下源碼:

// 源碼
func (rs *Rows) Next() bool {
	var doClose, ok bool
	withLock(rs.closemu.RLocker(), func() {
		doClose, ok = rs.nextLocked()
	})
	if doClose {
		rs.Close() //在這里釋放掉了
	}
	return ok
}

例子:

package main

import (
	"database/sql"
	_ "github.com/go-sql-driver/mysql"
)

var db *sql.DB
func mian() {
	db = sql.Open("mysql", "root:123456@tcp(127.0.0.1)/test")
	if err := db.Ping(); err != nil {
		panic(err)
	}
}

func Insert() {
	_, err := db.Exec("INSERT INTO User(user, pwd) VALUE (?, ?)", "laowang", "123456")
	if err != nil {
		panic(err)
	}
}

func SelectRow() {
	rows, err := db.Query("SELECT * FROM User WHERE user=?", "laowang")
	if err != nil {
		panic(err)
	}
	//defer rows.Close() //如果后面代碼沒有循環(huán)調(diào)用rows.Next(),就需要手動(dòng)在這里釋放一下,不然會(huì)一直占用緩存
	var user string
	var pwd string
	for rows.Next() {
		row.Scan(&user, &pwd)
	}
	print(user, pwd)
}

關(guān)于go操作mysql數(shù)據(jù)庫的方法就分享到這里了,當(dāng)然并不止以上和大家分析的辦法,不過小編可以保證其準(zhǔn)確性是絕對(duì)沒問題的。希望以上內(nèi)容可以對(duì)大家有一定的參考價(jià)值,可以學(xué)以致用。如果喜歡本篇文章,不妨把它分享出去讓更多的人看到。


名稱欄目:go操作mysql數(shù)據(jù)庫的方法介紹
標(biāo)題鏈接:http://weahome.cn/article/pgspih.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部