# 数据库读写分离
创建好EngineGroup之后,我们将可以对主从数据库(Master/Slave)进行SQL操作。例如:
~~~
import (
_ "github.com/lib/pq"
"github.com/xormplus/xorm"
)
var eg *xorm.EngineGroup
func main() {
conns := []string{
"postgres://postgres:root@localhost:5432/test?sslmode=disable;",
"postgres://postgres:root@localhost:5432/test1?sslmode=disable;",
"postgres://postgres:root@localhost:5432/test2?sslmode=disable",
}
var err error
eg, err = xorm.NewEngineGroup("postgres", conns)
if err != nil {
return
}
user := new(User)
user.Name = "myname"
affected, err := eg.Insert(user)
// INSERT INTO user (name) values (?)
if err != nil {
return
}
}
~~~
EngineGroup对数据库的SQL操作方法集和Engine是完全一致的,上例中则是对数据库进行Insert操作,写操作和数据库事务操作都将在Master数据库中执行。而读操作则是依据负载策略在某个Slave中执行。
## EngineGroup的Session
EngineGroup和Engine一样可以通过NewSession()方法来创建EngineGroup的Session,下例中,在同一个EngineGroup的Session中,执行写操作是在Master数据库中执行,执行读操作时则在Slave数据库执行。
>xorm并不推荐在同一个EngineGroup的Session中同时进行读写操作,如需要,请使用事务,事务操作将全部在Master数据库中执行读写操作。
~~~
session := eg.NewSession()
defer session.Close()
user := new(User)
user.Name = "myname"
affected, err := session.Insert(user)
// INSERT INTO user (name) values (?)
if err != nil {
return
}
_, err = session.Exec("delete from userinfo where username = ?", user2.Username)
if err != nil {
return
}
sql := "select * from userinfo"
results, err := engine.Query(sql)
if err != nil {
return
}
_, err = session.Exec("delete from userinfo where username = ?", user2.Username)
if err != nil {
return
}
~~~
- xorm
- 创建Orm引擎
- 定义表结构体
- 名称映射规则
- 前缀映射,后缀映射和缓存映射
- 使用Table和Tag改变名称映射
- Column属性定义
- 表结构操作
- 获取数据库信息
- 表操作
- 创建索引和唯一索引
- 同步数据库结构
- 导入导出SQL脚本
- SqlMap及SqlTemplate模板
- 初始化SqlMap配置文件及SqlTemplate模板
- SqlMap及SqlTemplate相关功能API
- SqlMap配置文件及SqlTemplate模板加密存储及解析
- 手动管理SqlMap配置及SqlTemplate模板
- 插入数据
- ORM方式插入数据
- 执行SQL命令插入数据
- 创建时间Created
- 查询和统计数据
- ORM方式查询和统计数据
- 查询条件方法
- 临时开关方法
- Get方法
- Find方法
- Join的使用
- Iterate方法
- Count方法
- Rows方法
- Sum系列方法
- Exist方法
- 子查询
- 执行SQL查询
- 执行SQL查询的11种常用方式
- 查询返回json或xml字符串
- 链式查询据操返回某条记录的某个字段的值
- SqlTemplateClient执行过程
- 关于数据库分页查询
- 更新数据
- ORM方式更新数据
- Update方法
- 乐观锁Version
- 更新时间Updated
- 执行SQL命令更新数据
- 删除数据
- ORM方式删除数据
- Delete方法
- 软删除Deleted
- 执行SQL命令删除数据
- 事务处理
- 简单事务模型
- 嵌套事务模型
- 八种事务类型及事务传播机制
- 简单事务相关API
- 嵌套事务相关API
- 嵌套事务示例代码
- 主从数据库(Master/Slave)读写分离
- 创建引擎组
- 负载策略
- 引擎组其他配置方法
- 数据库读写分离
- 批量混合SQL操作
- SQL Builder
- 缓存
- 事件
- 数据导出
- Dump数据库结构和数据
- 查询结果集导出csv、tsv、xml、json、xlsx、yaml、html
- 多Sheet页数据导出
- 日志
- 连接池
- xorm 工具
- 常见问题
- 感谢支持