中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

go操作mysql數據庫的方法介紹

發布時間:2020-04-24 14:02:57 來源:億速云 閱讀:615 作者:小新 欄目:編程語言

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

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

go操作mysql數據庫的方法介紹

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

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

sql.DB

DB類型可用的函數有:

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),其他語句,也可以用于執行上述語句,返回Stmt指針

sql.Stmt

Stmt是準備好的語句,可以執行數據庫語句操作,常用函數有:

Exec(args interface{} …) (Result, error),給定參數并執行準備好的語句,然后返回語句的總結果

//...
	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),給定參數并執行準備好的語句,返回行結果,比方說SELECT操作就必須用這個函數調用。

sql.Rows

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

// 源碼
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() //如果后面代碼沒有循環調用rows.Next(),就需要手動在這里釋放一下,不然會一直占用緩存
	var user string
	var pwd string
	for rows.Next() {
		row.Scan(&user, &pwd)
	}
	print(user, pwd)
}

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

顺平县| 乌拉特前旗| 师宗县| 永顺县| 大关县| 防城港市| 寿宁县| 上栗县| 民乐县| 贵溪市| 拉萨市| 古田县| 岑巩县| 科技| 抚松县| 仪征市| 进贤县| 波密县| 彭阳县| 克什克腾旗| 新宁县| 堆龙德庆县| 库伦旗| 布尔津县| 延寿县| 任丘市| 井陉县| 柏乡县| 正宁县| 遂平县| 鄂托克前旗| 北安市| 鲜城| 金堂县| 扎鲁特旗| 玛曲县| 定安县| 文登市| 康乐县| 景东| 乌兰察布市|