返回顶部
首页 > 资讯 > 数据库 >go语言中mysql怎么使用
  • 940
分享到

go语言中mysql怎么使用

2023-07-04 19:07:35 940人浏览 泡泡鱼
摘要

本篇内容介绍了“Go语言中mysql怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!golang支持多种数据库Mysqlmysql是一

本篇内容介绍了“Go语言中mysql怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

golang支持多种数据库

Mysql

mysql是一款关系型数据库管理系统,Mysql采用了双授权政策,可以将数据保存在不同的表中,从而增加数据库的速度和灵活性,具有体积小、速度快、总体拥有成本低的特点。

oracle

oracle是一款关系数据库管理系统,在数据库领域处于领先地位,领先地位具有可移植性好、使用方便、功能强的特点,适用于各类大、中、小、微机环境,是一种效率高、可靠性好、吞吐量高的数据库。

SQLite

SQLite是一款轻型数据库,其遵循ACID关系型数据库管理系统,其设计目的为嵌入式,所用可以在很多嵌入式产品中使用SQLite,同时可以和C#PHP、Java等程序语言相结合使用。

MongoDB

mongoDB是一个基于分布式文件存储的数据库,其目的是为WEB应用提供可扩展的高性能数据存储方案,MongoDB支持的数据结构非常松散,且支持多查询语言和建立索引

postgresql

PostgreSQL是一个功能强大、源代码开放的对象关系型数据库管理系统,具有复杂查询、外键、触发器、视图、事务完整性、多版本并发控制等特性,PostgreSQL可以通过函数在数据库服务器端执行指令程序,且用户可以自定义索引方法。

SQL Sever

SQL Sever是一个关系型数据库管理系统,具有使用方便、可伸缩性好、相关软件集成程度高的优点,可以提供更安全可靠的存储性能,使用SQL Sever可以构建和管理用于业务的高可用和高性能的数据应用程序。

golang操作MySQL数据库

下面主要从增删查改以及事物等方面介绍go语言中mysql的使用

一、连接数据库

使用sql.Open()函数打开数据库连接,数据库的连接字符串(dsn)格式如下:

admin:123456@tcp(10.2.1.5)/irisapp

代码如下:

func (f *mysql_db) mysql_open() {    db, err := sql.Open("mysql", dbusername+":"+dbpassWord+"@tcp("+dbhostsip+")/"+dbname)    if err != nil {        fmt.Println("链接失败")    }    fmt.Println("链接成功")    f.db = db}

二、插入

func (f *mysql_db) mysql_insert() { //insert  添加数据    fmt.Println("开始插入")    stmt, err := f.db.Prepare("INSERT INTO depart(departName,memo) VALUES(?,?)")    //defer stmt.Close()    if err != nil {        fmt.Println("插入失败")        return    }    stmt.Exec("dd", "adadcccda")    fmt.Println("插入成功")}

三、查询

func (f *mysql_db) mysql_select(sql_data string) {   //select 查询数据    fmt.Println("sql:", sql_data)    rows, err := f.db.Query(sql_data)    if err != nil {        fmt.Println("查询失败")    }    for rows.Next() {        var departID int        var departName string        var memo string        err = rows.Scan(&departID, &departName, &memo)        if err != nil {            panic(err)        }        fmt.Println("departName:", departName)    }}

四、更新

func (f *mysql_db) mysql_update() { //update  修改数据    stmt, err := f.db.Prepare("update depart set departName=?,memo =? where departId=?")    //defer stmt.Close()    if err != nil {        //错误处理    }    result,_ := stmt.Exec("aa","asdfadsadsfa",1)    if result == nil {        fmt.Println("修改失败")    }    affect_count,_ := result.RowsAffected()    //返回影响的条数,注意有两个返回值    fmt.Println("%v",affect_count)}

五、删除

func (f *mysql_db) mysql_delete() { //delete  删除数据    stmt, err := f.db.Prepare("delete from depart where departId=?")    //defer stmt.Close()    if err != nil {        //错误处理    }    stmt.Exec(2)     //不返回任何结果    fmt.Println("删除成功")}

六、事物

func (f *mysql_db) mysql_tran(){    //事务    tx,err := f.db.Begin()        //声明一个事务的开始    if err != nil {        fmt.Println(err)        return    }    insert_sql := "insert into depart (departName,memo) VALUES(?,?)"    insert_stmt,insert_err := tx.Prepare(insert_sql)    if insert_err != nil {        fmt.Println(insert_err)        return    }    insert_res,insert_err := insert_stmt.Exec("ff","ff")    last_insert_id,_ := insert_res.LastInsertId()    fmt.Println(last_insert_id)    // defer tx.Rollback()            //回滚之前上面的last_login_id是有的,但在回滚后该操作没有被提交,被回滚了,所以上面打印的Last_login_id的这条数据是不存在与数据库表中的    tx.Commit()                        //这里提交了上面的操作,所以上面的执行的sql 会在数据库中产生一条数据}

调用

func main() {    db := &mysql_db{}    db.mysql_open()    db.mysql_insert()    db.mysql_update()    db.mysql_delete()    db.mysql_tran()    db.mysql_select("select departID,departName,memo from depart")    db.mysql_close() //关闭}

启动后输出如下:

D:\Go_Path\go\src\mysqldemo>go run mysqldemo.go链接成功开始插入插入成功0删除成功10sql: select departID,departName,memo from departdepartName: aadepartName: DDDepartName: dddepartName: dddepartName: dddepartName: dddepartName: ffdepartName: dddepartName: ff

完整代码

package mainimport (    "database/sql"    "fmt"    _ "GitHub.com/go-sql-driver/mysql"    )var (    dbhostsip  = "10.2.1.5:3306"    dbusername = "admin"    dbpassword = "123456"    dbname     = "irisapp")type mysql_db struct {    db *sql.DB}func (f *mysql_db) mysql_open() {    db, err := sql.Open("mysql", dbusername+":"+dbpassword+"@tcp("+dbhostsip+")/"+dbname)    if err != nil {        fmt.Println("链接失败")    }    fmt.Println("链接成功")    f.db = db}func (f *mysql_db) mysql_close() {    defer f.db.Close()}func (f *mysql_db) mysql_select(sql_data string) {   //select 查询数据    fmt.Println("sql:", sql_data)    rows, err := f.db.Query(sql_data)    if err != nil {        fmt.Println("查询失败")    }    for rows.Next() {        var departID int        var departName string        var memo string        err = rows.Scan(&departID, &departName, &memo)        if err != nil {            panic(err)        }        fmt.Println("departName:", departName)    }}func (f *mysql_db) mysql_insert() { //insert  添加数据    fmt.Println("开始插入")    stmt, err := f.db.Prepare("INSERT INTO depart(departName,memo) VALUES(?,?)")    //defer stmt.Close()    if err != nil {        fmt.Println("插入失败")        return    }    stmt.Exec("dd", "adadcccda")    fmt.Println("插入成功")}func (f *mysql_db) mysql_update() { //update  修改数据    stmt, err := f.db.Prepare("update depart set departName=?,memo =? where departId=?")    //defer stmt.Close()    if err != nil {        //错误处理    }    result,_ := stmt.Exec("aa","asdfadsadsfa",1)    if result == nil {        fmt.Println("修改失败")    }    affect_count,_ := result.RowsAffected()    //返回影响的条数,注意有两个返回值    fmt.Println(affect_count)}func (f *mysql_db) mysql_delete() { //delete  删除数据    stmt, err := f.db.Prepare("delete from depart where departId=?")    //defer stmt.Close()    if err != nil {        //错误处理    }    stmt.Exec(2)     //不返回任何结果    fmt.Println("删除成功")}func (f *mysql_db) mysql_tran(){    //事务    tx,err := f.db.Begin()        //声明一个事务的开始    if err != nil {        fmt.Println(err)        return    }    insert_sql := "insert into depart (departName,memo) VALUES(?,?)"    insert_stmt,insert_err := tx.Prepare(insert_sql)    if insert_err != nil {        fmt.Println(insert_err)        return    }    insert_res,insert_err := insert_stmt.Exec("ff","ff")    last_insert_id,_ := insert_res.LastInsertId()    fmt.Println(last_insert_id)    // defer tx.Rollback()            //回滚之前上面的last_login_id是有的,但在回滚后该操作没有被提交,被回滚了,所以上面打印的Last_login_id的这条数据是不存在与数据库表中的    tx.Commit()                        //这里提交了上面的操作,所以上面的执行的sql 会在数据库中产生一条数据}func main() {    db := &mysql_db{}    db.mysql_open()    db.mysql_insert()    db.mysql_update()    db.mysql_delete()    db.mysql_tran()    db.mysql_select("select departID,departName,memo from depart")    db.mysql_close() //关闭}

“go语言中mysql怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

您可能感兴趣的文档:

--结束END--

本文标题: go语言中mysql怎么使用

本文链接: https://lsjlt.com/news/347119.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • go语言中mysql怎么使用
    本篇内容介绍了“go语言中mysql怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!golang支持多种数据库MySQLMySQL是一...
    99+
    2023-07-04
  • go语言中怎么使用select
    这篇文章主要介绍“go语言中怎么使用select”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“go语言中怎么使用select”文章能帮助大家解决问题。在golang语言中,select语句...
    99+
    2023-06-30
  • Go语言中defer语句怎么使用
    今天小编给大家分享一下Go语言中defer语句怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.在一个函数内的def...
    99+
    2023-07-02
  • 怎么使用GO语言
    这篇文章主要讲解了“怎么使用GO语言”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用GO语言”吧!什么是 GVMGo 语言版本管理器(GVM)是管理 Go 语言环境的开源工具。GVM ...
    99+
    2023-06-16
  • Go语言中的iota怎么使用
    今天小编给大家分享一下Go语言中的iota怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一...
    99+
    2024-04-02
  • go语言中for range怎么使用
    这篇文章主要介绍“go语言中for range怎么使用”,在日常操作中,相信很多人在go语言中for range怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”go语言中for range怎么使用”的疑...
    99+
    2023-07-04
  • go语言中的decimal怎么使用
    这篇文章主要介绍了go语言中的decimal怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇go语言中的decimal怎么使用文章都会有所收获,下面我们一起来看看吧。decimal是为了解决Golang中...
    99+
    2023-07-05
  • Go语言中unsafe包怎么使用
    本文小编为大家详细介绍“Go语言中unsafe包怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Go语言中unsafe包怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1. 什么是unsafe包un...
    99+
    2023-07-05
  • Go语言中的sync.Pool怎么使用
    本篇内容介绍了“Go语言中的sync.Pool怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 简介本文将介绍 Go 语言中的 s...
    99+
    2023-07-05
  • go语言中怎么使用openssl库
    在Go语言中使用OpenSSL库可以通过调用C语言的接口来实现。首先需要安装CGO工具,然后在Go代码中引入C语言的头文件和库文件,...
    99+
    2024-04-09
    go语言 openssl
  • Go语言dolphinscheduler怎么使用
    这篇文章主要介绍了Go语言dolphinscheduler怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Go语言dolphinscheduler怎么使用文章都会有所收获,下面我们一起来看看吧。自动化为什...
    99+
    2023-07-02
  • Go语言中的链表怎么使用
    本篇内容主要讲解“Go语言中的链表怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Go语言中的链表怎么使用”吧!1. 什么是链表链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的...
    99+
    2023-06-30
  • Go语言中转义符怎么使用
    这篇文章主要讲解了“Go语言中转义符怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Go语言中转义符怎么使用”吧!在Go语言中,转义字符是一种特殊的字符常量,以反斜线"\&q...
    99+
    2023-07-05
  • go语言中join方法怎么使用
    这篇“go语言中join方法怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“go语言中join方法怎么使用”文章吧。在...
    99+
    2023-07-05
  • Go语言中的包Package怎么使用
    本文小编为大家详细介绍“Go语言中的包Package怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Go语言中的包Package怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。问题一、Go使用Pac...
    99+
    2023-07-02
  • Go语言中循环Loop怎么使用
    本篇内容介绍了“Go语言中循环Loop怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Go语言和其他语言不一样,它只有一种循环方式,就...
    99+
    2023-07-02
  • Go语言中的接口怎么使用
    今天小编给大家分享一下Go语言中的接口怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。接口在 Go 语言中,接口是一种...
    99+
    2023-07-04
  • Go语言中的闭包怎么使用
    这篇文章主要讲解了“Go语言中的闭包怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Go语言中的闭包怎么使用”吧!闭包基本介绍闭包就是 一个函数 和其相关的&nbs...
    99+
    2023-07-04
  • Go语言中interface类型怎么使用
    今天小编给大家分享一下Go语言中interface类型怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Go语言中int...
    99+
    2023-07-06
  • Go语言中的事务怎么使用
    本篇内容主要讲解“Go语言中的事务怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Go语言中的事务怎么使用”吧!事务实践服务端在进行和数据库交互时,对于一些场景我们可能会使用事务来保证数据...
    99+
    2023-07-06
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作