- 51
- 0
代码package mainimport ( "gorm.io/driver/mysql" "gorm.io/gorm")type RequestLink struct { ID uint `gorm:"primaryKey"` Link string IsOpen int `gorm:"column:is_open"` CreateTime string `gorm:"column:create_time"` UpdateTime string `gorm:"column:update_time"`}func init() { dsn := "root:root@tcp(127.0.0.1:3306)/test?charset=utf8mb4&parseTime=True&loc=Local" database, _ := gorm.Open(mysql.Open(dsn), &gorm.Config{}) Gorm = database}func (c *RequestLink) TableName() string { return "request_link"}var Gorm *gorm.DBfunc main() { x := RequestLink{} x.Query1() x.Query2()}func (c *RequestLink) Query1() { var data2 []RequestLink Gorm = Gorm.Where("create_time > ?", "2021-11-21 09:00:00") Gorm.Debug().First(&data2)}func (c *RequestLink) Query2() { var link = "qq" var is_open = "1" var data2 []RequestLink Gorm = Gorm.Where("link like ?", "%"+link+"%") Gorm = Gorm.Where("is_open = ?", is_open) Gorm.Debug().First(&data2)}查询条件,函数1只有时间查询,函数2没有时间查询。查询结果,很明显看到函数2累加了函数1的查询条件SELECT * FROM `request_link` WHERE create_time > '2021-11-21 09:00:00' LIMIT 1SELECT * FROM `request_link` WHERE create_time > '2021-11-21 09:00:00' AND link like '%qq%' AND is_open = '1' LIMIT 1暂时的解决办法,在每次查询先用变量接收Gorm,这样是可以避免条件累加。但是这样写不方便、一旦忘记用变量接收就会影响全局SQLvar db = Gorm db.Find(&data)考虑有更多表要用查询,这里要怎样改才更好 呢
0
打赏
收藏
点击回答
网站公告
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部

