既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
人工智能和大数据分析: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()
}`
运行效果如下图
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
…(img-QEfV2BYN-1715557918695)]
[外链图片转存中…(img-6nsAkD9B-1715557918695)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新