ZBLOG

go 初始化mysql连接 ,实现函数化

在Go语言中,可以使用第三方库如go-sql-driver/mysql来初始化MySQL连接并实现函数化。以下是一个示例代码:

package main

import (
	"database/sql"
	"fmt"

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

func main() {
	db, err := InitDB()
	if err != nil {
		fmt.Println("Failed to connect to MySQL:", err)
		return
	}
	defer db.Close()

	err = DoSomethingWithDB(db)
	if err != nil {
		fmt.Println("Error occurred while working with MySQL:", err)
		return
	}

	fmt.Println("Successfully executed MySQL operations.")
}

// 初始化数据库连接
func InitDB() (*sql.DB, error) {
	db, err := sql.Open("mysql", "username:password@tcp(host:port)/database")
	if err != nil {
		return nil, err
	}

	err = db.Ping()
	if err != nil {
		return nil, err
	}

	return db, nil
}

// 在这里进行数据库操作的函数化实现
func DoSomethingWithDB(db *sql.DB) error {
	stmt, err := db.Prepare("INSERT INTO users(name, age) VALUES(?, ?)")
	if err != nil {
		return err
	}
	defer stmt.Close()

	result, err := stmt.Exec("John Doe", 30)
	if err != nil {
		return err
	}

	lastInsertID, _ := result.LastInsertId()
	rowsAffected, _ := result.RowsAffected()

	fmt.Printf("Last inserted ID: %d\nRows affected: %d\n", lastInsertID, rowsAffected)

	return nil
}

请替换代码中的usernamepasswordhostportdatabase为您自己的MySQL连接信息。这样,您就可以通过调用InitDB()来初始化数据库连接,并在DoSomethingWithDB()中进行具体的数据库操作。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=8443

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?