补充:xorm高级部分
===
### 事务及回滚
- 创建session对象
`sess := Engine.NewSession()`
- 启动事任
`sess.Begin()`
- 通过session操作数据库
`sess.Update()`
- 发生错误进行回滚
`sess.RollBack()`
- 提交事务
`sess.Commit()`
为什么要用到事务?保证数据的一致性 原子性 隔离性 持久性
我们就吧那个转账模块修改一下吧
```
func TransferAccounts(form,to string,balance float64) error {
session := Engine.NewSession() // 获得session
defer session.Close() // session会消耗资源 所以要关闭
err := session.Begin() //开启事务
if err != nil {
return errors.New("session begin error")
}
account := &Account{Name: form}
_, e := Engine.Get(account)
if e != nil {
return e
}
if account.Balance > balance{
account.Balance -= balance
}
account2 := &Account{Name:to}
b, e := Engine.Get(account2)
if b != true || e!= nil{
return errors.New("Error")
}
account2.Balance += balance
_, e = Engine.Where("name = ?",account.Name).Update(account)
if e!=nil{
session.Rollback() //回滚
return e
}
_, e = Engine.Where("name = ?",account2.Name).Update(account2)
if e!=nil{
session.Rollback() //回滚
}
return session.Commit() //提交
}
```
### 这节课程的大块头讲完了,就是小部分了
#### 统计
- 统计某个表中服务条件的所有记录条数
`Engine.Count(new(Account))`
- 配合链式操作
`Engine.Where("id > 10").Count(new(Account))`
#### 迭代查询
- 迭代查询某个表中符合条件的所有记录
```
Engine.Iterate(new(Account),func(idx int,bean interface{}) {
fmt.Printf("%d,%#v\n",idx,bean.(*Account))
})
```
- 使用Rows对象
`rows,err := Engine.Rows(new(Account))`
```
func row() {
rows, _ := Engine.Rows(new(Account))
defer rows.Close()
account := new(Account)
for rows.Next() {
rows.Scan(account)
}
}
```
#### 常用查询方法
- 当只有结构中的某个字段的值对你有价值时:
`Engine.Clos("name").Get(..)`
- 忽略指定字段
`Engine.Omit("name").Find(...)`
- 分页
`Engine.Limit(3,2).Find(...)`
#### 日志记录
- 开启日志
`Engine.ShowSQL = true`
- 将日志保存到文件
```
f,_ := os.Create("sql.log")
Engine.Logger = xorm.NewSimpleLogger(f)
```
#### LRU缓存
- 开启默认LRU缓存
```
cacher := xormNewLRUCacher(xorm.NewMemoryStore(),1000)
Engine.SetDefaultCacher(cacher)
```
#### 事件钩子
这个去看官方文档吧....
本次课程代码:
[https://github.com/dollarkillerx/GolangWebCourseware/tree/xorm](https://github.com/dollarkillerx/GolangWebCourseware/tree/xorm)
- 初认GOlang Web
- 关于环境配置
- 路由
- 路由进阶与目录架构
- 静态文件服务器
- 自定义Middleware
- 与MySQL起舞
- 主从模式概念
- 部署主从集群
- 分库分表
- 补充:事务
- 补充:常用SQL示例
- Template使用
- 一些小的,但是要知道的东西
- 调度任务
- 流控算法
- 鉴权
- JWT鉴权前置知识:加密解密
- session
- 文件上传与下载
- 带缓存读写拷贝io
- 参考
- 写好的文件上传
- 文件下载
- 拓展:秒传功能实现
- 扩展:分块上传和断点续传
- 扩展:分块上传
- 扩展:断点续传
- 扩展:分布式存储
- 部署ceph集群
- cephAuth
- go操作ceph集群
- 扩展:云存储
- go操作oss
- 补充:xorm框架
- 命令小结
- 补充:xorm框架高级部分
- 补充
- MongoDB
- 基础概念
- 简简单单NoSql
- 操作集合(Collection)
- 操作文档(Document)
- 带条件的文档 db.find
- 复杂条件抽文档 db.find
- redis
- redis操作
- go操作redis
- (新增)配置鉴权
- 密码学
- 文件校验算法
- 未来课程的安排
- RPC实践
- 爬虫
- 正则表达式
- 爬取手机号
- 爬取邮箱
- 爬取超链接
- 爬取身份证号
- 并发爬图片
- 扩展:CICD
- GO实现自动化部署系统
- 国际化支持
- 并发带来问题的解决
- GOWEB小知识
- Sync包讲解
- sync.Pool
- 千万级WebSocket消息推送
- 微服务入门:开篇
- 路由通讯
- RabbitMQ
- RabbitMQ工作原理和转发模式
- Dcoker 下 RabbitMQ and Ui
- Go操作RabbitMQ
- 初步微服务
- go-micro
- 补充:consul
- 快速入门
- 补充:consul超时
- 微服务架构
- 微服务架构全景图
- 服务注册和发现
- raft协议基本概念
- raft协议leader选举详解
- raft协议日志复制详解
- raft协议safefy详解
- rpc调用个服务监控
- etcd
- 命令行使用
- Golang操作etcd
- GO操作etcd OP方式 (分布式锁基础)
- etcd 分布式集群乐观锁
- (新增)鉴权
- 服务注册
- 服务发现原理
- 选项设计模式介绍
- 基于插件的注册组建
- 课前知识
- etcd注册开发1
- ffmpeg
- 2.0新的启航
- 高可用Mysql
- mysql逻辑架构
- 常见的MySQL高可用方案
- 索引
- MYSQL调优
- 什么影响了MYSQL的性能
- Mysql 服务器参数配置
- Go深入并发
- 基本同步原语
- 扩展同步原语
- 原子操作
- M P G 模型
- 简单的消息总线
- GoMicro入门
- GO任务池编写
- GO依赖注入
- 一些补充
- golang defer在什么时候执行
- 分布式理论篇(面试吹牛必备)
- CAP理论
- Raft协议
- 保证注册中心的可靠性
- 链路追踪
- 怎么实现强一致性