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,
})

相关内容

热门资讯

科普透视!拱趴大菠萝怎么开挂,... 科普透视!拱趴大菠萝怎么开挂,pokermaster修改器(透视)原来是有辅助教程(哔哩哔哩)一、拱...
科普透视!德州辅助工具到底怎么... 科普透视!德州辅助工具到底怎么样,epoker免费透视脚本(透视)好像真的有辅助脚本(哔哩哔哩)1、...
推荐透视!拱趴大菠萝有什么挂,... 推荐透视!拱趴大菠萝有什么挂,约局吧开挂神器是真的吗(透视)好像真的是有辅助app(哔哩哔哩)1、完...
曝光透视!云扑克有透视吗,德州... 曝光透视!云扑克有透视吗,德州局透视脚本下载安装最新版本(透视)好像真的是有辅助软件(哔哩哔哩)1、...
教你透视!sohoo辅助,po... 教你透视!sohoo辅助,pokemmo辅助器(透视)一贯真的有辅助神器(哔哩哔哩)1、pokemm...
详细透视!拱趴大菠萝挂哪里,拱... 详细透视!拱趴大菠萝挂哪里,拱趴大菠萝有挂吗(透视)本来一直总是有辅助插件(哔哩哔哩)进入游戏-大厅...
关于透视!来玩app 德州 辅... 关于透视!来玩app 德州 辅助,werplan透视挂(透视)原来一直总是有辅助方法(哔哩哔哩)1、...
揭幕透视!agpoker辅助,... 揭幕透视!agpoker辅助,pokemmo脚本辅助下载(透视)确实一直总是有辅助技巧(哔哩哔哩)p...
分享透视!哈糖大菠萝挂,pok... 分享透视!哈糖大菠萝挂,pokerworld软件(透视)本来是真的有辅助软件(哔哩哔哩)1、玩家可以...
必备透视!智星德州插件,aa ... 必备透视!智星德州插件,aa poker辅助(透视)一贯真的是有辅助攻略(哔哩哔哩)智星德州插件能透...