账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    Glang gorm库执行SQL查询,不同函数之间查询条件会累加是什么原因?
    15
    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
    更多回答
    扫一扫访问手机版

    回答动态

    渊海:发布了悬赏问题9414754预计能赚取 10积分收益
    发布了悬赏问题9414754预计能赚取 10积分收益
    发布了悬赏问题9414754预计能赚取 0积分收益
    神奇的四哥:发布了悬赏问题9414754预计能赚取 10积分收益
    发布了悬赏问题9414754预计能赚取 0积分收益
    发布了悬赏问题9414754预计能赚取 10积分收益
    发布了悬赏问题9414754预计能赚取 0积分收益
    发布了悬赏问题9414754预计能赚取 11积分收益
    发布了悬赏问题9414754预计能赚取 10积分收益
    じ☆ve萌爱灬:发布了悬赏问题9414754预计能赚取 0积分收益