准备工作

创建测试账户

运行 root 账户执行命令。

-- 创建 go 
CREATE USER 'go'@'localhost' IDENTIFIED BY '123456'; 

-- 添加所有权限 
GRANT ALL PRIVILEGES ON *.* TO 'go'@'localhost'; 

-- 刷新权限 
FLUSH PRIVILEGES;

执行建表语句

创建并且使用数据库。

create database go;
use go;

创建表:

CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(255)
);

insert into users (name) values ('1');
insert into users (name) values ('2');
insert into users (name) values ('3');

数据验证:

mysql> select * from users;
+----+------+
| id | name |
+----+------+
|  1 | 1    |
|  2 | 2    |
|  3 | 3    |
+----+------+

代码

库安装

在 Go 语言中访问 MySQL 数据库,你需要使用第三方库来进行数据库操作。

一个常用的库是 github.com/go-sql-driver/mysql,它提供了与 MySQL 数据库交互的功能。

安装 mysql 库

> go get -u github.com/go-sql-driver/mysql
go: go.mod file not found in current directory or any parent directory.
        'go get' is no longer supported outside a module.
        To build and install a command, use 'go install' with a version,
        like 'go install example.com/cmd@latest'
        For more information, see https://golang.org/doc/go-get-install-deprecation
        or run 'go help get' or 'go help install'.

解决办法

办法1:命令行输入

go env -w GO111MODULE=auto

办法2:初始化Go moudle,在目录下运行下面命令

go mod init XXX //xxx代表文件夹名

实战

方式1:可以安装,但是代码中好像还是要处理。

go env -w GO111MODULE=auto

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

方式2:处理对应的包,引入 module


2.1 初始化对应的 mod

go mod init example.com/database

go: creating new go.mod: module example.com/database
go: to add module requirements and sums:
        go mod tidy

2.2 引入

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

go: module github.com/go-sql-driver/mysql: Get "https://proxy.golang.org/github.com/go-sql-driver/mysql/@v/list": dial tcp 142.251.42.241:443: connectex: A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond.

安装报错。

这是因为无法对外网进行访问,可以通过输入一下命令进入代理网站进行访问

go env -w GOPROXY=https://goproxy.cn,direct

重新安装:

λ go get github.com/go-sql-driver/mysql
go: downloading github.com/go-sql-driver/mysql v1.7.1
go: added github.com/go-sql-driver/mysql v1.7.1

入门例子

下面是一个简单的入门示例,演示如何在 Go 中访问 MySQL 数据库:

package main

import (
	"database/sql"
	"fmt"

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

func main() {
	// 连接数据库
	dsn := "go:123456@tcp(127.0.0.1:3306)/go"
	db, err := sql.Open("mysql", dsn)
	if err != nil {
		panic(err)
	}
	defer db.Close()

	// 查询数据库
	rows, err := db.Query("SELECT id, name FROM users")
	if err != nil {
		panic(err)
	}
	defer rows.Close()

	// 处理查询结果
	for rows.Next() {
		var id int
		var name string
		if err := rows.Scan(&id, &name); err != nil {
			panic(err)
		}
		fmt.Printf("ID: %d, Name: %s\n", id, name)
	}

	if err := rows.Err(); err != nil {
		panic(err)
	}
}

运行

go run main.go

效果如下:

> go run main.go

ID: 1, Name: 1
ID: 2, Name: 2
ID: 3, Name: 3

直接就查出来了。

PS: 发现如果直接把 module 信息移除,这里直接处理应该也可以。不过包的安装还需要后续深入学习。

go module介绍

go module是go官方自带的go依赖管理库,在1.13版本正式推荐使用

go module可以将某个项目(文件夹)下的所有依赖整理成一个 go.mod 文件,里面写入了依赖的版本等 使用

go module之后我们可不用将代码放置在src下了 使用 go module 管理依赖后会在项目根目录下生成两个文件 go.mod 和go.sum

GO111MODULE

GO111MODULE是 go modules 功能的开关,关于go modules本文不详述,这个涉及到go的一种很重要的管理机制,我们可以简单的理解为,在没有go modules机制时,go工程中对于第三方功能包的管理非常复杂,也非常专业,这就导致程序员在进行开发的时候,对于第三方功能包的管理很不方便,所以才有了go modules机制。

这个机制的开关是通过GO111MODULE环境变量来配置的。

GO111MODULE=off,无模块支持,go命令行将不会支持module功能,寻找依赖包的方式将会沿用旧版本那种通过vendor目录或者GOPATH模式来查找。

GO111MODULE=on,模块支持,go命令行会使用modules,而一点也不会去GOPATH目录下查找。

GO111MODULE=auto,默认值,go命令行将会根据当前目录来决定是否启用module功能。

这种情况下可以分为两种情形:

(1)当前目录在GOPATH/src之外且该目录包含go.mod文件,开启模块支持。

(2)当前文件在包含go.mod文件的目录下面。

参考资料

https://go.dev/doc/tutorial/add-a-test

https://www.techdatao.com/article/detail/57.html