使用Go语言操作MySQL数据库的思路与步骤
时间:2022-06-08
本文章向大家介绍使用Go语言操作MySQL数据库的思路与步骤,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
最近在做注册登录服务时,学习用Go语言操作MySQL数据库实现用户数据的增删改查,现将个人学习心得总结如下,另外附有代码仓库地址,欢迎各位有兴趣的fork。
软件环境:Goland、Navicat for MySQL。
一、实现思路
1,我的总体设计思路是先写出连接数据库和关闭数据库的逻辑,再建立四个分支,根据用户的选择分别进入增删改查的操作;
func DBstart() {
db,_= sql.Open("mysql", "root:123456@tcp(127.0.0.1:3306)/dbtest?charset=utf8") //dbtest为我新建立的数据库名
fmt.Println("mysql start succcessed !")
}
func DBclose(){
//关闭数据库
db.Close()
fmt.Println("database closed")
}
2,增加的操作
输入对应的数据
fmt.Println("请输入用户ID:")
fmt.Scan(&Userid)
fmt.Println("请输入名字:")
fmt.Scan(&Username)
fmt.Println("请输入部门:")
fmt.Scan(&Departname)
fmt.Println("请输入进部门时间")
fmt.Scan(&Created)
//插入数据
stmt,err := db.Prepare("INSERT userif SET userid=?,username=?,departname=?,created=?")
CheckErr(err)
res,err := stmt.Exec(Userid,Username,Departname,Created)
CheckErr(err)
id,err := res.LastInsertId()
fmt.Println(id)
3,查询的操作
rows,err := db.Query("SELECT * FROM userif")
CheckErr(err)
for rows.Next(){
err = rows.Scan(&Id,&Userid,&Created,&Departname,&Username)
CheckErr(err)
fmt.Println(Userid)
fmt.Println(Username)
fmt.Println(Departname)
fmt.Println(Created)
}
4,更新的操作
根据提示输入要更新的内容,然后转到对应的更新语句
fmt.Println("请输入要查询的用户ID:")
fmt.Scan(&Userid)
fmt.Println("请输入要更新的内容:a-名字;b-部门;c-进部门的时间:")
var s string
fmt.Scan(&s)
switch s {
case "a":
fmt.Println("请输入要更改用户ID为%d的名字",Userid)
fmt.Scan(&Username)
fmt.Println(Username)
fmt.Println(Userid)
stmt,err := db.Prepare("UPDATE userif SET username=? where userid=?")
CheckErr(err)
......//以此类推
}
5,删除的操作
fmt.Println("请输入要删除的用户ID:")
fmt.Scan(&Userid)
stmt,err := db.Prepare("DELETE from userif where userid=?")
CheckErr(err)
res,err := stmt.Exec(Userid)
CheckErr(err)
affect,err := res.RowsAffected()
CheckErr(err)
fmt.Println(affect)
二、注意点
1,在查找操作中注意输入与输出对应的列名是否与MySQL数据中的一致,不然可能会造成如下错误

三、参考资料
- 《大话数据结构》 查找 以及一个简单的哈希表例子
- 《大话数据结构》树以及赫夫曼编码的例子
- 《大话数据结构》一些基础知识
- Golang RPC 之 gRPC
- 厚土Go学习笔记 | 06. 变量
- 厚土Go学习笔记 | 05. 函数
- Implement Domain Object in Golang
- 厚土Go学习笔记 | 04. 导入和导出的不同 用math.Pi来举例
- 厚土Go学习笔记 | 03. 数学运算的随机数
- Nodejs学习笔记(十一)--- 数据采集器示例(request和cheerio)
- 厚土Go学习笔记 | 02. 打印当前时间time.Now()时不我待
- 厚土Go学习笔记 | 01. Hello World开篇
- Golang精编100题
- IntelliJ idea配置Go开发环境
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解
- java多线程学习(3)-线程池
- 用python来玩好玩的之自动抽奖
- 整合ThinkPHP功能系列之使用聚合数据查询快递物流数据
- python中一切皆对象
- 整合ThinkPHP功能系列之微信公众号模板消息发送
- 自己动手写令牌桶、漏桶、计数等限流实现
- JVM中的[Ljava.lang.Object; 究竟是什么意思?
- 图解Fork/Join
- 不标题党地学习G1
- 使用G1 GC,降低内存消耗20%
- 面试官问他Java中“a”+“b”究竟会产生几个对象?
- 源码走读-从JedisCluster的设计来发现对象池的奥秘
- Python入门:在Debian系统安装Python 3
- JDK11中增加了一个常量池类型:CONSTANT_Dynamic
- 使用 SCF 无服务器云函数定时拨测站点并邮件告警