golang使用go-sql-driver实现mysql增删改操作

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介:

这两天用golang  写的服务端做的都是和redis做交互,因为后期还会用mysql的一个表做验证。  先学习下golang对mysql的操作  !

mymysql和go-mysql-driver是两个现在都很流行的go的mysql驱动,看了下文档,后者比较的健全,听大牛们介绍,貌似go-mysql-driver更加的健全。



安装配置还是那么简单,直接go get就可以了


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



好了,咱们就开始用go-sql-driver增删改查


先用go-sql-driver链接mysql !!!


一看就懂了,帐号:密码@模式           数据库,以及附带的参数


1
2
3
user@unix(/path/to/socket)/dbname
root:pw@unix(/tmp/mysql.sock)/myDatabase?loc=Local
user:password@tcp(localhost: 5555 )/dbname?tls=skip-verify&autocommit= true


完整的例子!

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
//xiaorui.cc
#xiaorui.cc
package  main
import  (
     "database/sql"  //这包一定要引用,是底层的sql驱动
     "fmt"
     "github.com/go-sql-driver/mysql"
     "strconv"  //这个是为了把int转换为string
)
func main() {   //main函数
     db, err := sql.Open( "mysql" "root:@tcp(localhost:3306)/dbname?charset=utf8" )
     //数据库连接字符串,别告诉我看不懂。端口一定要写/
        if  err != nil {   //连接成功 err一定是nil否则就是报错
                 panic(err.Error())  //抛出异常
         fmt.Println(err.Error()) //仅仅是显示异常
     }
     defer db.Close()   //只有在前面用了 panic 这时defer才能起作用,如果链接数据的时候出问题,他会往err写数据
                                                                                 
     rows, err := db.Query( "select id,lvs from xiaorui" )
     //判断err是否有错误的数据,有err数据就显示panic的数据
     if  err != nil {
                 panic(err.Error())
         fmt.Println(err.Error())
         return
     }
     defer rows.Close()
     var  id  int   //定义一个id 变量
     var  lvs string  //定义lvs 变量
     for  rows.Next() {  //开始循环
         rerr := rows.Scan(&id, &lvs)   //数据指针,会把得到的数据,往刚才id 和 lvs引入
         if  rerr == nil {
             fmt.Println( "id号是" ,strconv.Itoa(id) +  "     lvs lvs是" + lvs)  //输出来而已,看看
         }
     }
         insert_sql :=  "INSERT INTO xiaorui(lvs) VALUES(?)"
         _, e4 := db.Exec(insert_sql, "nima" )                                                            
         fmt.Println(e4)
        db.Close()  //关闭数据库
}


wKioL1MxLCWy7L-qAAIYdscA1JM573.jpg





 本文转自 rfyiamcool 51CTO博客,原文链接:http://blog.51cto.com/rfyiamcool/1383842,如需转载请自行联系原作者



相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
3月前
|
SQL Oracle 关系型数据库
MySQL的sql_mode模式说明及设置
MySQL的sql_mode模式说明及设置
576 112
|
2月前
|
SQL 存储 关系型数据库
MySQL体系结构详解:一条SQL查询的旅程
本文深入解析MySQL内部架构,从SQL查询的执行流程到性能优化技巧,涵盖连接建立、查询处理、执行阶段及存储引擎工作机制,帮助开发者理解MySQL运行原理并提升数据库性能。
|
4月前
|
存储 SQL 关系型数据库
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
|
1月前
|
Java 编译器 Go
【Golang】(1)Go的运行流程步骤与包的概念
初次上手Go语言!先来了解它的运行流程吧! 在Go中对包的概念又有怎样不同的见解呢?
110 4
|
1月前
|
Java 编译器 Go
【Golang】(5)Go基础的进阶知识!带你认识迭代器与类型以及声明并使用接口与泛型!
好烦好烦好烦!你是否还在为弄不懂Go中的泛型和接口而烦恼?是否还在苦恼思考迭代器的运行方式和意义?本篇文章将带你了解Go的接口与泛型,还有迭代器的使用,附送类型断言的解释
136 3
|
1月前
|
存储 安全 Java
【Golang】(4)Go里面的指针如何?函数与方法怎么不一样?带你了解Go不同于其他高级语言的语法
结构体可以存储一组不同类型的数据,是一种符合类型。Go抛弃了类与继承,同时也抛弃了构造方法,刻意弱化了面向对象的功能,Go并非是一个传统OOP的语言,但是Go依旧有着OOP的影子,通过结构体和方法也可以模拟出一个类。
128 1
|
2月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
|
2月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
2月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。

热门文章

最新文章

推荐镜像

更多