Go语言介绍以及如何在Go语言中操作MySQL数据库

人不走空

                                                                      

      🌈个人主页:人不走空      

💖系列专栏:算法专题

⏰诗词歌赋:斯是陋室,惟吾德馨

目录

      🌈个人主页:人不走空      

💖系列专栏:算法专题

⏰诗词歌赋:斯是陋室,惟吾德馨

一、Go语言介绍

二、Go语言特点

三、  Go语言应用场景

四、Go语言环境安装

五、Go语言实现Mysql数据库的增删概啥

安装操作数据库依赖Go-MySQL-Driver

代码实现

作者其他作品:


今天给大家介绍一下Go语言,以及实现MySQL数据库的操作示例,希望对大家能有所帮助!

图片

一、Go语言介绍

Go语言,也称为Golang,是由Google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程语言。以下是Go语言的一些主要特点:

二、Go语言特点

语法简洁:摒弃了一些复杂的编程概念和冗余的语法,容易学习

高效性能:采用的静态编译和垃圾回收机制,实现了高效的内存管理

并发支持:Go语言是为并发编程而设计的,原生支持goroutine和channel

强大的标准库:Go语言拥有丰富的标准库

社区活跃:Go语言的社区非常活跃,有着庞大的开发者群体

图片

三、  Go语言应用场景

图片

服务器端开发:适合构建高性能的服务器端应用程序。因为Go语言具有轻量级的协程(goroutine)和高效的并发编程机制。例如谷歌、Dropbox和Netflix等。

网络编程:适合构建Web服务器、微服务、网络爬虫、实时通信系统等。目前Go语言成为开发高负载网络应用的首选语言。

云计算:Go语言的轻量级和快速编译的特点使得它非常适合于构建云原生应用。例如Docker和Kubernetes等。

系统编程:适合成为开发操作系统、驱动程序和嵌入式系统。

工具开发:很多工具和框架都选择使用Go语言进行开发。例如,Docker、Etcd、InfluxDB和Prometheus等工具。

人工智能和大数据分析:Go语言的并发编程模型和内存管理机制使得它可以高效地处理大规模数据和复杂计算任务。

四、Go语言环境安装

安装Go语言环境,首先官网下载WindowsGo语言安装包

https://golang.google.cn/dl/

图片

安装之后,cmd运行命令检查环境是否安装成功。

图片

五、Go语言实现Mysql数据库的增删概啥

安装操作数据库依赖Go-MySQL-Driver

Go-MySQL-Driver是Go语言官方推荐的MySQL驱动, 是Go语言中使用MySQL的最佳选择

 

go get -u github.com/go-sql-driver/mysql

可能会报如下错误:

图片

原因

GO111MODULE 是 Go 1.11 引入的新版模块管理方式。

GO111MODULE 环境变量用于开启或关闭 Go 语言中的模块支持,它有 off、on、auto 三个可选值,默认为 auto

win10环境下需要执行如下命令:

 

go env -w GO111MODULE=auto
 

然后重新执行安装命令

 

go get -u github.com/go-sql-driver/mysql

如果下载的时候报错

 

connectex: A connection attempt failed because the connected party did not p

直接进入电脑的环境变量设置国内镜像地址

新建环境变量GOPROXY

值为

 

https://mirrors.aliyun.com/goproxy/

图片

点击确定后,重启命令行窗口,然后执行下载命令

图片

代码实现

 

package main

import (

  "database/sql"
  "fmt"
  "log"

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




/*
*获取mysql数据库版本
*/
func showMysqlVersion() {
db, err := sql.Open("mysql", "root:12345678@tcp(127.0.0.1:3306)/test2?charset=utf8")
if err != nil {
log.Fatal(err)
}
db.Ping()
defer db.Close()

var version string

errt2 := db.QueryRow("SELECT VERSION()").Scan(&version)

if errt2 != nil {
log.Fatal(errt2)
}

fmt.Println(version)

}
/*
*查询数据测试
*/
func queryTest() {
// 设置数据库连接信息
db, err := sql.Open("mysql", "root:12345678@tcp(127.0.0.1:3306)/test2")
if err != nil {
log.Fatal(err)
}
defer db.Close()

// 执行查询
rows, err := db.Query("SELECT id, name, age FROM t_user")
if err != nil {
log.Fatal(err)
}
defer rows.Close()

// 遍历查询结果
for rows.Next() {
var id int
var name string
var age int
if err := rows.Scan(&id, &name, &age); err != nil {
log.Fatal(err)
}
fmt.Printf("ID: %d, Name: %s, Age: %d\n", id, name, age)
}
if err := rows.Err(); err != nil {
log.Fatal(err)
}
}


/*
*插入数据测试
*/
func insertTest() {
db, err := sql.Open("mysql", "root:12345678@tcp(127.0.0.1:3306)/test2")
db.Ping()
defer db.Close()

if err != nil {
fmt.Println("connect DB error !")
log.Fatalln(err)
}

_, err2 := db.Query("INSERT INTO t_user ( `name`, `address`, `age`) VALUES('小刘','广东',35)")
if err2 != nil {
log.Fatal(err2)
}

fmt.Println("数据插入成功")

}
/*
*数据更新测试
*/
func updateTest() {
db, err := sql.Open("mysql", "root:12345678@tcp(127.0.0.1:3306)/test2")
db.Ping()
defer db.Close()

if err != nil {
fmt.Println("connect DB error !")
log.Fatalln(err)
}

_, err2 := db.Query("update t_user set name='小明2' where id=1 ")
if err2 != nil {
log.Fatal(err2)
}

fmt.Println("数据更新成功")

}

/*
*数据更新测试
*/
func delTest() {
db, err := sql.Open("mysql", "root:12345678@tcp(127.0.0.1:3306)/test2")
db.Ping()
defer db.Close()

if err != nil {
fmt.Println("connect DB error !")
log.Fatalln(err)
}

_, err2 := db.Query("delete from t_user where id=2 ")
if err2 != nil {
log.Fatal(err2)
}

fmt.Println("数据删除成功")

}

func main(){
delTest()
updateTest();
//insertTest()
queryTest()
showMysqlVersion()
}


 

运行效果如下图

图片


作者其他作品:

【Java】Spring循环依赖:原因与解决方法

OpenAI Sora来了,视频生成领域的GPT-4时代来了

[Java·算法·简单] LeetCode 14. 最长公共前缀 详细解读

【Java】深入理解Java中的static关键字

[Java·算法·简单] LeetCode 28. 找出字a符串中第一个匹配项的下标 详细解读

了解 Java 中的 AtomicInteger 类

算法题 — 整数转二进制,查找其中1的数量

深入理解MySQL事务特性:保证数据完整性与一致性

Java企业应用软件系统架构演变史

  • 31
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

人不走空

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值