标签:requested use err sql mysql go password native
文章目录
go 连接 mysql 问题
参考官方文档
https://go.dev/doc/tutorial/database-access
var db *sql.DB
func main() {
// Capture connection properties.
cfg := mysql.Config{
User: os.Getenv("DBUSER"),
Passwd: os.Getenv("DBPASS"),
Net: "tcp",
Addr: "127.0.0.1:3306",
DBName: "recordings",
}
// Get a database handle.
var err error
db, err = sql.Open("mysql", cfg.FormatDSN())
if err != nil {
log.Fatal(err)
}
pingErr := db.Ping()
if pingErr != nil {
log.Fatal(pingErr)
}
fmt.Println("Connected!")
}
报错:
zego@zegodeMacBook-Pro-53 data-access % go run main.go
[mysql] 2021/12/16 11:23:02 connector.go:95: could not use requested auth plugin 'mysql_native_password': this user requires mysql native password authentication.
2021/12/16 11:23:02 this user requires mysql native password authentication.
exit status 1
解决方法:添加 AllowNativePasswords: true,
cfg := mysql.Config{
User: os.Getenv("DBUSER"),
Passwd: "123456",
Net: "tcp",
Addr: "127.0.0.1:3306",
DBName: "recordings",
AllowNativePasswords: true,
}
参考文档中说明该参数默认为 true,我这边不知道何原因为 false
当设为 false 表示不允许使用 MySQL 原生密码方法
参数文档
https://github.com/go-sql-driver/mysql#dsn-data-source-name
解决方案参考链接
https://github.com/go-sql-driver/mysql/issues/815
标签:requested,use,err,sql,mysql,go,password,native 来源: https://blog.csdn.net/Alu_em/article/details/122015179
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。