AsSplitQuery每个查询都要单独往返于数据库,为什么?
创始人
2024-09-20 19:30:13
0

AsSplitQuery是GORM中的一个方法,它使得一个查询可以分成多个小查询,这样可以减缓处理大量数据的压力。但是,它在每个小查询中都会单独往返于数据库,造成数据库压力的增加。要解决这个问题,可以通过设置GORM的配置参数来让AsSplitQuery在一个连接中同时进行多个小查询,从而减少往返次数。

示例代码:

import "gorm.io/gorm"

// 设置数据库连接池大小,避免连接过多导致性能下降
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{
    MaxIdleConns:   10,
    MaxOpenConns:   100,
})

// 设置GORM的配置参数
db.Session(&gorm.Session{
    // 关闭日志,减少对性能的影响
    Logger:      nil,
    // 设置每个小查询的最大数量
    BatchSize:   1000,
    // 开启连接池模式,每个连接可以同时处理多个小查询
    PrepareStmt: true,
    // 启用一个事务来处理所有的小查询
    PrepareStmt: true,
    // 启用 SQL 绑定,可以缓存 Prepared Statement,提高查询速度
    PrepareStmt: true,
})

相关内容

热门资讯

无独有偶!aapoker透视脚... 无独有偶!aapoker透视脚本入口,wejoker开挂(透视)专业教程(有挂讲解)-哔哩哔哩1、完...
这一现象值得深思!hh pok... 这一现象值得深思!hh poker软件,云扑克有透视吗(透视)解密教程(的确有挂)-哔哩哔哩1、云扑...
据文件显示!wepoker高级... 据文件显示!wepoker高级辅助,哈糖大菠萝助手(透视)解密教程(有挂分享)-哔哩哔哩据文件显示!...
透视软件!wpk控制牌是真的吗... 透视软件!wpk控制牌是真的吗,wepoker怎么挂底牌(透视)透视教程(有挂方针)-哔哩哔哩1、w...
透视科技!wepoker免费钻... 透视科技!wepoker免费钻石,wepoker有透视底牌吗(透视)开挂教程(确实有挂)-哔哩哔哩1...
透视私人局!fishpoker... 透视私人局!fishpoker透视,聚星ai辅助工具下载(透视)解谜教程(有挂方式)-哔哩哔哩1、下...
透视软件!aapoker脚本,... 透视软件!aapoker脚本,wepoker如何设置透视(透视)总结教程(有挂详情)-哔哩哔哩1、下...
据了解!wpk辅助是真的吗,拱... 据了解!wpk辅助是真的吗,拱趴大菠萝辅助神器(透视)曝光教程(详细教程)-哔哩哔哩1、首先打开拱趴...
透视肯定!wepoker辅助器... 透视肯定!wepoker辅助器,aapoker怎么选牌(透视)解迷教程(真的有挂)-哔哩哔哩1、aa...
透视教程!hhpoker有透视... 透视教程!hhpoker有透视功能吗,德普之星透视辅助插件(透视)了解教程(有挂头条)-哔哩哔哩1、...