技术文摘
Golang 如何使用 MySQL 数据库
Golang 如何使用 MySQL 数据库
在Golang开发中,与MySQL数据库交互是常见需求。下面将介绍如何在Golang项目里使用MySQL数据库。
需要安装MySQL驱动。目前广泛使用的是go-sql-driver/mysql,通过命令go get -u github.com/go-sql-driver/mysql即可完成安装。
接着,在代码中引入必要的包:
package main
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"
)
这里的database/sql是Go标准库中用于数据库操作的包,而_ "github.com/go-sql-driver/mysql"是引入MySQL驱动,下划线表示只执行包的初始化代码,不使用包中的导出标识符。
然后,进行数据库连接。连接MySQL数据库的代码如下:
func connectDB() (*sql.DB, error) {
dsn := "user:password@tcp(127.0.0.1:3306)/database_name"
db, err := sql.Open("mysql", dsn)
if err!= nil {
return nil, err
}
err = db.Ping()
if err!= nil {
return nil, err
}
return db, nil
}
在dsn中,需要填入实际的用户名、密码、数据库地址和数据库名。sql.Open用于打开数据库连接,db.Ping用于测试连接是否成功。
执行SQL查询是使用数据库的重要部分。例如,执行简单的查询操作:
func queryData(db *sql.DB) {
rows, err := db.Query("SELECT column1, column2 FROM table_name")
if err!= nil {
fmt.Println("查询失败:", err)
return
}
defer rows.Close()
for rows.Next() {
var column1 string
var column2 int
err := rows.Scan(&column1, &column2)
if err!= nil {
fmt.Println("扫描结果失败:", err)
return
}
fmt.Printf("column1: %s, column2: %d\n", column1, column2)
}
}
db.Query用于执行查询语句,返回rows结果集。通过rows.Next遍历结果集,rows.Scan将结果集中的数据扫描到定义的变量中。
插入、更新和删除操作与查询类似。以插入操作为例:
func insertData(db *sql.DB) {
stmt, err := db.Prepare("INSERT INTO table_name (column1, column2) VALUES (?,?)")
if err!= nil {
fmt.Println("准备语句失败:", err)
return
}
defer stmt.Close()
result, err := stmt.Exec("value1", 123)
if err!= nil {
fmt.Println("执行插入失败:", err)
return
}
lastInsertId, err := result.LastInsertId()
if err!= nil {
fmt.Println("获取插入ID失败:", err)
return
}
fmt.Printf("插入成功,最后插入ID: %d\n", lastInsertId)
}
db.Prepare用于准备SQL语句,防止SQL注入。stmt.Exec执行插入操作,result.LastInsertId获取最后插入的ID。
在Golang中使用MySQL数据库并不复杂,通过合理使用标准库和驱动,能高效地完成数据库的各种操作,为开发稳定、高效的应用程序提供支持。
TAGS: 数据库操作 Golang MySQL数据库 Golang与MySQL
- 利用 Oracle 中的 emp 和 dept 学习 Django ORM
- 第十二期挨踢部落坐诊:千万级 Web 请求的分发之道
- 2018 年就业前景最佳的 7 大编程语言:Java、Python、JavaScript 居前三,PHP 亦在列!
- 重磅!阿里内部 678 页技术干货下载
- 一天找不到 Bug ?Git 二分法来帮忙!
- Kotlin 可读性优于 Java 的原因何在?
- Ajax 跨域的最全解决方案
- 程序员怎样保护自身?
- 马斯克向 1670 万粉丝误发手机号 或需改号
- Spring Cloud 构建微服务架构:消息驱动的微服务入门(Dalston 版)
- AI 全面来袭,2040 年程序员还能继续敲代码吗?
- 基于 Python 构建企业认证与权限控制平台的方法
- 八年游戏开发程序员的未来忧思
- 几十万程序员对“Java 市场是否饱和”的评论
- Python 爬虫实战:百度云资源的抓取与保存