首页 > 数据库 >如何使用Go语言进行数据库操作

如何使用Go语言进行数据库操作

时间:2024-01-05 16:34:53浏览次数:38  
标签: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. 查询数据

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. 插入数据

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. 更新数据

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. 删除数据

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

相关文章

  • 寻找最懂数据库RDS的你,成为阿里云云大使,拉新赢取猫超卡及返佣礼金!
    ......
  • Docker一键极速安装Nacos,并配置数据库!
    1部署方式1.1DockerHubjavaedge@JavaEdgedeMac-mini~%dockerrun--namenacos\-eMODE=standalone\-eJVM_XMS=128m\-eJVM_XMX=128m\-eJVM_XMN=64m\-eJVM_MS=64m\-eJVM_MMS=64m\-p8848:8848\-dnacos/nacos-server:v2.2.3a624c64a1a25ad2d......
  • UI测试平台RunnerGo一键安装教程
    现在安装RunnerGo仅需要一条命令!目前支持系统:Centos、Debian、Ubuntu三种。下面给大家介绍一下RunnerGo安装使用流程:Step1:复制以下命令wgethttps://img.cdn.apipost.cn/running_go/img/wiki/runnergo.tar&&tarxfrunnergo.tar&&bashinstall.shStep2:选择安装系统输入命令......
  • Docker一键极速安装Nacos,并配置数据库!
    1部署方式1.1DockerHubjavaedge@JavaEdgedeMac-mini~%dockerrun--namenacos\-eMODE=standalone\-eJVM_XMS=128m\-eJVM_XMX=128m\-eJVM_XMN=64m\-eJVM_MS=64m\-eJVM_MMS=64m\-p8848:8848\-dnacos/nacos-server:v2.2.3a624c64a1a25ad2d......
  • UI测试平台RunnerGo一键安装教程
    现在安装RunnerGo仅需要一条命令!目前支持系统:Centos、Debian、Ubuntu三种。下面给大家介绍一下RunnerGo安装使用流程:Step1:复制以下命令wget https://img.cdn.apipost.cn/running_go/img/wiki/runnergo.tar&&tarxf runnergo.tar  &&bashinstall.shStep2:选择安装系统......
  • window如何安装sqlite3数据库
    1.SQLite学习笔记一:Windows下安装SQLite 一、简介• SQLite是一个轻型的数据库,无需任何服务,无需任何配置的绿色数据库。• SQLite是一个进程内库,它实现了一个自包含、无服务器、零配置、事务性SQL数据库引擎。SQLite的代码在公共域中,因此可以免费用于任何目的,无论是商业还......
  • ArgoCD用户管理
    1.创建用户alicekubectlapply-fargocd-cm.yamlapiVersion:v1kind:ConfigMapmetadata:name:argocd-cmnamespace:argocdlabels:app.kubernetes.io/name:argocd-cmapp.kubernetes.io/part-of:argocddata:#addanadditionallocaluserwitha......
  • Bclinux系统安装MongoDB
    1、下载安装包wgethttps://fastdl.mongodb.org/linux/mongodb-linux-x86_64-4.0.28.tgz2、解压重命名[test@localhost~]$tar-zxvfmongodb-linux-x86_64-4.0.28.tgz[test@localhost~]$rm-rfmongodb-linux-x86_64-4.0.28.tgz[test@localhost~]$mvmongodb-linux-x86_64......
  • MySQL8.0 PG数据库 SQLServer Oracle数据库 数据库忘记密码 处理方法
    MySQL8.0分为rpm方式和tar.gz安装方式不同而不同需要修改/etc/my.conf配置文件.注意如果是rpm包的话就在这个路径下面修改增加内容skip-grant-tables注意修改完需要重启数据库rpm包安装的方式重启方法为:systemctlrestartmysqld然后可以无密码登录数据mysql-uro......
  • pycharm配置sqlite3数据库 可视化插件
    1.首先你需要创建一个sqlite3数据库,创建好数据库以后会生成一个.db后缀名或者.sqlite后缀的数据库文件。如果你不知道window如何安装sqlite3数据库,请参考我的这篇文章:如果你不知道如何使用sqlite3,请参考我的这篇文章: 3.要在pycharm中打开.sqlite后缀的数据库文件和打开.db......