标签:return 语言 err nil 数据库 stmt Println Go fmt
如何使用Go语言进行数据库操作 https://www.php.cn/faq/587088.html
引言:
Go语言是一种高效且简洁的编程语言,拥有强大的并发能力和优秀的性能表现。在开发过程中,与数据库的交互是一个非常重要的环节。本文将介绍如何使用Go语言进行数据库操作,包括连接数据库、CRUD操作以及事务处理等。
一、连接数据库
在Go语言中,我们可以使用各种数据库驱动来连接不同类型的数据库,如MySQL、PostgreSQL、SQLite等。以MySQL为例,首先需要安装MySQL驱动。在命令行中执行以下命令即可:
1
|
go get github.com/go-sql-driver/mysql
|
接下来,我们可以创建一个数据库连接池,以便快速获取和释放数据库连接。示例代码如下所示:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"
)
func main() {
db, err := sql.Open( "mysql" , "username:password@tcp(localhost:3306)/databaseName?charset=utf8" )
if err != nil {
fmt. Println ( "数据库连接失败:" , err)
return
}
defer db. Close ()
err = db.Ping()
if err != nil {
fmt. Println ( "数据库连接失败:" , err)
return
}
fmt. Println ( "连接数据库成功!" )
}
|
二、CRUD操作
以下是Go语言中常见的数据库操作示例代码。
- 查询数据
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
func queryData(db *sql.DB) {
rows, err := db.Query( "SELECT id, name, age FROM users" )
if err != nil {
fmt. Println ( "查询数据失败:" , err)
return
}
defer rows. Close ()
for rows.Next() {
var id int
var name string
var age int
err := rows.Scan(&id, &name, &age)
if err != nil {
fmt. Println ( "读取数据失败:" , err)
return
}
fmt. Println ( "ID:" , id, "Name:" , name, "Age:" , age)
}
if err := rows.Err(); err != nil {
fmt. Println ( "遍历数据失败:" , err)
return
}
}
|
- 插入数据
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
func insertData(db *sql.DB) {
stmt, err := db.Prepare( "INSERT INTO users(name, age) VALUES(?, ?)" )
if err != nil {
fmt. Println ( "插入数据失败:" , err)
return
}
defer stmt. Close ()
result, err := stmt.Exec( "张三" , 20 )
if err != nil {
fmt. Println ( "插入数据失败:" , err)
return
}
rowAffected, err := result.RowsAffected()
if err != nil {
fmt. Println ( "获取影响的行数失败:" , err)
return
}
fmt. Println ( "成功插入" , rowAffected, "行数据。" )
}
|
- 更新数据
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
func updateData(db *sql.DB) {
stmt, err := db.Prepare( "UPDATE users SET age=? WHERE name=?" )
if err != nil {
fmt. Println ( "更新数据失败:" , err)
return
}
defer stmt. Close ()
result, err := stmt.Exec( 25 , "张三" )
if err != nil {
fmt. Println ( "更新数据失败:" , err)
return
}
rowAffected, err := result.RowsAffected()
if err != nil {
fmt. Println ( "获取影响的行数失败:" , err)
return
}
fmt. Println ( "成功更新" , rowAffected, "行数据。" )
}
|
- 删除数据
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
func deleteData(db *sql.DB) {
stmt, err := db.Prepare( "DELETE FROM users WHERE name=?" )
if err != nil {
fmt. Println ( "删除数据失败:" , err)
return
}
defer stmt. Close ()
result, err := stmt.Exec( "张三" )
if err != nil {
fmt. Println ( "删除数据失败:" , err)
return
}
rowAffected, err := result.RowsAffected()
if err != nil {
fmt. Println ( "获取影响的行数失败:" , err)
return
}
fmt. Println ( "成功删除" , rowAffected, "行数据。" )
}
|
三、事务处理
在进行数据库操作时,有时需要保证多个操作的原子性,即要么全部成功,要么全部失败。这时就需要使用事务处理。示例代码如下所示:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
func transaction(db *sql.DB) {
tx, err := db.Begin()
if err != nil {
fmt. Println ( "开启事务失败:" , err)
return
}
defer tx.Rollback()
stmt, err := tx.Prepare( "INSERT INTO users(name, age) VALUES(?, ?)" )
if err != nil {
fmt. Println ( "插入数据失败:" , err)
return
}
defer stmt. Close ()
_, err = stmt.Exec( "张三" , 20 )
if err != nil {
fmt. Println ( "插入数据失败:" , err)
return
}
stmt, err = tx.Prepare( "UPDATE users SET age=? WHERE name=?" )
if err != nil {
fmt. Println ( "更新数据失败:" , err)
return
}
defer stmt. Close ()
_, err = stmt.Exec( 25 , "张三" )
if err != nil {
fmt. Println ( "更新数据失败:" , err)
return
}
err = tx.Commit()
if err != nil {
fmt. Println ( "提交事务失败:" , err)
return
}
fmt. Println ( "事务处理成功!" )
}
|
结论:
本文介绍了如何使用Go语言进行数据库操作,包括连接数据库、CRUD操作以及事务处理等。通过学习这些示例代码,相信大家可以更好地使用Go语言操作数据库,提高程序的性能和效率。希望本文对大家有所帮助!
标签:return,
语言,
err,
nil,
数据库,
stmt,
Println,
Go,
fmt
From: https://www.cnblogs.com/jason-zhao/p/17947550