登录
首页 >  Golang >  Go问答

使用bolthold进行BoltDB检索操作

来源:stackoverflow

时间:2024-02-13 19:48:23 299浏览 收藏

你在学习Golang相关的知识吗?本文《使用bolthold进行BoltDB检索操作》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

问题内容

我正在尝试使用 go 创建boltdb 查询。

我必须有一个查询来检查角色和租户id。基本上,该项目必须始终包含角色,如果该项目具有租户id,则它必须匹配,但是如果该项目没有租户id(如果为nil),它也必须返回它。

所以我提出了下面的查询来检查角色和租户 id,但不检查租户 id 是否为零。有人能帮我解决这个问题吗?考虑到租户id为nil,我需要添加什么到这个查询中?

query := bolthold.Where(roleskey).ContainsAny(bolthold.Slice(roles)...).And(tenantIDKey).Eq(tenantID)

正确答案


您可以使用or条件来检查它是否等于tenantidkeyisnil

query := bolthold.
         where(roleskey).
         containsany(bolthold.slice(roles)...).
         and(tenantidkey).isnil().
         or(
           bolthold.
           where(tenantidkey).
           eq(tenantid)
         )
query := bolthold.
         where(roleskey).
         containsany(bolthold.slice(roles)...).
         and(tenantidkey).
         eq(tenantid).
         or(
            bolthold.
            where(tenantidkey).
            isnil()
         )

您也可以用 in 代替 containsany

query := bolthold.
         Where(roleskey).
         In(bolthold.Slice(roles)...).
         And(tenantIDKey).IsNil().
         Or(
           bolthold.
           Where(tenantIDKey).
           Eq(tenantID)
         )

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

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