后端实践--go与数据库 青训营

简介: 后端实践--go与数据库 青训营

go与数据库

数据库在后端开发中十分重要,这篇博客主要总结用go去操作数据库的相关知识。包括数据库的简单介绍,重点是用go控制MySQL

1. 数据库简介

关系型数据库:MySQLSQLlite(嵌入式)、postgreSQL...... 用表存一类数据。

1. SQL 语句

DDL

DML

DCL

2. 存储引擎

常见的如MYISAMInnoDB

3. 索引

略。

4. 事务

ACID 四个特性。四个隔离级别。

5. go操作MySQL

go自带的包:database/sql 原生支持连接池并且是并发安全的。

没有具体的实现,列出了一些实现标准。

下载mysql依赖:go get ... 相关方法实现在这里。

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

连接数据库:sql.Open()db.Ping()

// 全局
var db *sql.DB
// 数据库用户名:密码@连接对象/具体哪一个数据库
dsn := "root:m3479735881@tcp(127.0.0.1:3306)/go_study"
// Open 时不校验用户名和密码,而是检查dsn的格式,返回值db就是一个数据库的连接池
// 这里一定不是 := ,因为前面声明过了!
db, err = sql.Open("mysql", dsn)
if err != nil {
  return
}
// 这里校验
err = db.Ping()
if err != nil {
  return
}
// 可以设置db这个数据库连接池中连接的最大个数
db.SetMaxOpenConns(10)
// 设置最大闲置连接数
// db.SetMaxIdleConns(8)

db对象放在全局,这样各个函数里就可以共享。db就像是一个句柄,里面有数据库的相关信息。

单行查询:db.QueryRow()

// 全局
type stu struct {
  id   int
  name string
  age  int
}
var stu1 stu
// 1. 查询
sqlStr := "select id,name,age from student where id=?;"
// 从连接池中取出一个连接去查询。
ret := db.QueryRow(sqlStr, i)
// 取出结果放到结构体里,同时Scan内部会释放连接!  !所以一般必须调用Scan释放连接
ret.Scan(&stu1.id, &stu1.name, &stu1.age)
fmt.Printf("%#v\n", stu1

需要注意最后一定要调用Scan ,因为Scan 内部会释放该连接,不释放就会造成连接浪费。

多行查询:db.Query()

sqlStr := "select id,name,age from student where id > ?;"
rets, err := db.Query(sqlStr, i)
if err != nil {
  fmt.Printf("Query error:%#v\n", err)
  return
}
// 这个要自己手动关闭!
defer rets.Close()
// 循环取值
var stu1 stu
for rets.Next() {
  rets.Scan(&stu1.id, &stu1.name, &stu1.age)
  fmt.Printf("%#v\n", stu1)
}

一定注意使用的连接要手动关闭!

插入数据、更新数据、删除数据:db.Exec()

// 插入数据
sqlStr := "insert into student values (?, ?, ?)"
req, err := db.Exec(sqlStr, id, name, age)
if err != nil {
  fmt.Printf("Exec error:%#v\n", err)
  return
}
// 获取插入数据的ID
req.LastInsertId()
// 获取受影响的行数
req.RowsAffected()
// 修改数据
sqlStr := "update student set age=1111 where id=1;"
res, err := db.Exec(sqlStr)
if err != nil {
  fmt.Printf("Exec error:%#v\n", err)
  return
}
// 获取修改数据的ID
res.LastInsertId()
// 获取受影响的行数
res.RowsAffected()
// 删除数据
// 差别不大!!!

6. MySQL的预处理

把多条SQL语句的命令部分和数据部分 分开发给服务端,可以对同一类的语句做优化,提升效率。还可以避免SQL注入问题。适用于批量处理同一类的语句。

普通SQL语句执行过程:

  1. 客户端对SQL语句进行占位符替换得到完整的SQL语句。
  2. 客户端发送完整SQL语句到MySQL服务端
  3. MySQL服务端执行完整的SQL语句并将结果返回给客户端。

预处理执行过程:

  1. SQL语句分成两部分,命令部分与数据部分。
  2. 先把命令部分发送给MySQL服务端,MySQL服务端进行SQL预处理。
  3. 然后把数据部分发送给MySQL服务端,MySQL服务端对SQL语句进行占位符替换。
  4. MySQL服务端执行完整的SQL语句并将结果返回给客户端。
sqlStr := "insert into student values (?,?,?)"
// 预处理
stmt, err := db.Prepare(sqlStr)
if err != nil {
  fmt.Printf("prepare error:%#v\n", err)
  return
}
defer stmt.Close()
// 插入,填入之前的占位符即可
req, err := stmt.Exec(10, "asdfsadf", 123)
if err != nil {
  fmt.Printf("prepare error:%#v\n", err)
  return
}
req.LastInsertId()
// req.RowsAffected()

7. MySQL注入

==永远不要自己拼接SQL 语句!!==

// 自己拼接:
func select(name string){
  // 拼接,这时若name乱搞,就可能会有问题!!
  sqlStr := fmt.Sprintf("select id,name from student where name=%s", name)
}

8. sqlx使用

是对标准库database/sql 的替代。需要安装依赖。

就是比标准库的某些基础操作简单一点点。其实就用标准库就行。

2. Redis

KV数据库

下载第三方依赖:

go get github.com/go-redis/redis/v8

3. NSQ

分布式==消息队列。==

支持横向扩展;支持容错和高可用性;提供可靠的消息交付保证。

使用场景:同步处理转为异步处理(异步化);应用解耦;流量削峰(某一时刻流量非常大时提供一定的缓冲).......

以上就是go和数据库的简单介绍,有兴趣的可以继续深入了解。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
3月前
|
消息中间件 缓存 NoSQL
Redis各类数据结构详细介绍及其在Go语言Gin框架下实践应用
这只是利用Go语言和Gin框架与Redis交互最基础部分展示;根据具体业务需求可能需要更复杂查询、事务处理或订阅发布功能实现更多高级特性应用场景。
309 86
|
5月前
|
分布式计算 算法 安全
Go语言泛型-泛型约束与实践
Go语言中的泛型约束用于限制类型参数的范围,提升类型安全性。通过接口定义约束,可实现对数值类型、排序与比较等操作的支持。开发者既可使用标准库提供的预定义约束,如constraints.Ordered和constraints.Comparable,也可自定义约束以满足特定需求。泛型广泛应用于通用数据结构(如栈、队列)、算法实现(如排序、查找)及构建高效可复用的工具库,使代码更简洁灵活。
|
6月前
|
设计模式 人工智能 Go
go 依赖注入实践
依赖注入(DI)是一种软件设计模式,旨在降低代码耦合度,提高代码可测试性和可复用性。其核心思想是将依赖项从外部传入使用对象,而非由其内部创建。通过 DI,模块间关系更清晰,便于维护和扩展。常见实现包括方法注入和接口注入,适用于如 Go 等支持函数式编程和接口抽象的语言。
148 8
|
6月前
|
开发框架 JSON 中间件
Go语言Web开发框架实践:路由、中间件、参数校验
Gin框架以其极简风格、强大路由管理、灵活中间件机制及参数绑定校验系统著称。本文详解其核心功能:1) 路由管理,支持分组与路径参数;2) 中间件机制,实现全局与局部控制;3) 参数绑定,涵盖多种来源;4) 结构体绑定与字段校验,确保数据合法性;5) 自定义校验器扩展功能;6) 统一错误处理提升用户体验。Gin以清晰模块化、流程可控及自动化校验等优势,成为开发者的优选工具。
|
6月前
|
开发框架 安全 前端开发
Go Web开发框架实践:模板渲染与静态资源服务
Gin 是一个功能强大的 Go Web 框架,不仅适用于构建 API 服务,还支持 HTML 模板渲染和静态资源托管。它可以帮助开发者快速搭建中小型网站,并提供灵活的模板语法、自定义函数、静态文件映射等功能,同时兼容 Go 的 html/template 引擎,具备高效且安全的页面渲染能力。
|
6月前
|
开发框架 JSON 中间件
Go语言Web开发框架实践:使用 Gin 快速构建 Web 服务
Gin 是一个高效、轻量级的 Go 语言 Web 框架,支持中间件机制,非常适合开发 RESTful API。本文从安装到进阶技巧全面解析 Gin 的使用:快速入门示例(Hello Gin)、定义 RESTful 用户服务(增删改查接口实现),以及推荐实践如参数校验、中间件和路由分组等。通过对比标准库 `net/http`,Gin 提供更简洁灵活的开发体验。此外,还推荐了 GORM、Viper、Zap 等配合使用的工具库,助力高效开发。
|
7月前
|
设计模式 缓存 算法
Go如何进行高质量编程与性能调优实践
本文介绍了Go语言高质量编程与性能调优的实践方法。高质量编程包括良好的编码习惯(如清晰注释、命名规范)、代码风格与设计(如MVC模式)、简洁明了的代码原则,以及单元测试与代码重构的重要性。性能调优方面,涵盖算法优化、数据结构选择、I/O优化、内存管理、并行与并发处理优化及代码层面的改进。通过这些方法,可有效提升代码质量和系统性能。
167 13
|
5月前
|
Linux Go 开发者
Go语言泛型-泛型约束与实践
《Go语言实战指南》介绍了如何使用Go进行交叉编译,即在一个操作系统上编译出适用于不同系统和架构的二进制文件。通过设置GOOS和GOARCH环境变量,开发者可轻松构建跨平台程序,无需在每个平台上单独编译。Go从1.5版本起原生支持此功能,极大提升了多平台部署效率。
|
11月前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
546 2

热门文章

最新文章