当前位置: 首页 > news >正文

详解gorm中DB对象的clone属性

详解gorm中DB对象的clone属性

Gorm 版本:v1.22.4

Where函数源码

// Where add conditions
func (db *DB) Where(query interface{}, args ...interface{}) (tx *DB) {tx = db.getInstance()if conds := tx.Statement.BuildCondition(query, args...); len(conds) > 0 {tx.Statement.AddClause(clause.Where{Exprs: conds})}return
}func (db *DB) getInstance() *DB {if db.clone > 0 {tx := &DB{Config: db.Config, Error: db.Error}if db.clone == 1 {// clone with new statementtx.Statement = &Statement{DB:       tx,ConnPool: db.Statement.ConnPool,Context:  db.Statement.Context,Clauses:  map[string]clause.Clause{},Vars:     make([]interface{}, 0, 8),}} else {// with clone statementtx.Statement = db.Statement.clone()tx.Statement.DB = tx}return tx}return db
}
  • db.Open() 使db的clone=1
  • db.Begin() 使db的clone=1 (在https://github.com/go-gorm/gorm/pull/5012中修改为1,以前开启事务后clone是2)
  • db.Where() 使db的clone=0

使用Where前(重点!!!)

  • clone为1的话,是在新的数据库对象tx上构造查询条件(原db并没有修改),如果不接受Where()返回的tx,则会丢失构造的where条件;
  • clone为0的话,是在调用where的db对象本身上构造查询条件,所以可以不用接受Where()返回值;

使用场景

  1. clone为0时,构造同一条sql,db对象使用多个where。
  2. clone为1时,构造不同的sql,该db对象调用多个where,它本身的clone一直会是1。调用的where返回的tx的clone是0。那我们每条sql都是从最初的db调用的where的返回值(tx对象,clone=0)开始,然后又到了第一种情况。

一般的使用顺序:先使用 db.Open()或db.Begin()(返回了新的 db2)去开一条新 sql,再在这个db2 上使用 Where()构造这条 sql。

http://www.lryc.cn/news/285672.html

相关文章:

  • 数据库(MySQL库表操作)
  • 内网穿透的应用-如何使用Docker部署Redis数据库并结合内网穿透工具实现公网远程访问
  • 计算机网络复试
  • Android学习之路(23)组件化框架ARouter的使用
  • HCIA vlan练习
  • Ubuntu下安装Gazebo仿真器
  • Chatgpt+Comfyui绘图源码说明及本地部署文档
  • ts中 any 和 unknown 有什么区别,分别什么时候使用
  • C++中命名空间、缺省参数、函数重载
  • 【笔记】Helm-3 主题-12 Helm插件指南
  • 2023.1.17 关于 Redis 持久化 AOF 策略详解
  • P2PNet推理和训练
  • pyexecjs原生js加密算法逆向
  • 数据结构Java版(4)——链表
  • cfssl简单使用
  • 基于Word2vec词聚类的关键词实现
  • 开源项目_大模型应用_Chat2DB
  • 【线性代数与矩阵论】范数理论
  • 【C++】priority_queue模拟实现过程中值得注意的点
  • Git提交 ssh: connect to host github.com port 22: Connection timed out解决方案
  • Java调用WebService接口,SOAP协议HTTP请求返回XML对象
  • Django框架二
  • 工业相机与镜头参数及选型
  • VSCode使用Makefile Tools插件开发C/C++程序
  • 用C语言验证“三门定理”
  • 计算机网络-分层结构,协议,接口,服务
  • 前端开发 2: CSS
  • 嵌入式-Stm32-江科大基于标准库的GPIO4个小实验
  • HackTheBox - Medium - Linux - Noter
  • Uniapp多选Popup(弹出层)