登录
首页 >  Golang >  Go问答

使用 GORM 在 WHERE 子句中添加双括号实现“IN”操作

来源:stackoverflow

时间:2024-02-06 11:23:12 225浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《使用 GORM 在 WHERE 子句中添加双括号实现“IN”操作》,这篇文章主要讲到等等知识,如果你对Golang相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

问题内容

我正在使用 where 子句通过 gorm 更新数据库中的值

db.Session(&gorm.Session{FullSaveAssociations: true}).Where("id IN (?)", ids).Updates(users)

ids 是 ids 的一部分,用户是结构

问题是我收到此错误

错误1241(21000):操作数应包含1列

gorm生成的sql就是这个。看起来它创建了一个双括号,导致了这个错误。但我不知道如何解决这个问题

UPDATE `users` SET `status`='CANCELED',`updated_at`='2023-12-12 20:39:40.904' WHERE id IN (('066a75df-ba11-49c8-9b39-b1cce029760e','5f95f93e-94a5-46d1-86eb-dde83437ea26'))

编辑 1

我从 (?) 中删除 () 也有同样的效果

db.Session(&gorm.Session{FullSaveAssociations: true}).Where("id IN ?", ids).Updates(users)

UPDATE `users` SET `status`='CANCELED',`updated_at`='2023-12-12 21:18:46.537' WHERE id IN (('066a75df-ba11-49c8-9b39-b1cce029760e','5f95f93e-94a5-46d1-86eb-dde83437ea26'))

错误1241(21000):操作数应包含1列


正确答案


我在这里找到了答案https://github.com/go-gorm/ gorm/issues/5014https://gorm.io/docs/sql_builder。 html#子句

使用这个子句我可以做这样的事情

query.Clauses(
            clause.Where{
                Exprs: []clause.Expression{
                    clause.Expr{
                        SQL:                "id IN ?",
                        Vars:               []interface{}{ids},
                        WithoutParentheses: true,
                    },
                },
            },
        )

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>