V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
some3284
V2EX  ›  Go 编程语言

GO 语言中,不定条件,不定有值的模糊查询怎么写?

  •  
  •   some3284 · 2019-09-29 09:22:59 +08:00 · 5506 次点击
    这是一个创建于 1888 天前的主题,其中的信息可能已经有所发展或是发生改变。

    例:页面两个查询框,分别是姓名,地址,模糊查询时,可能只有一个查询框有值,也可能两个都有值。
    :这该怎么写 sql ?
    备注:目前看过:gorm 中只支持固定条件,必定有值的模糊查询;和不定有值,不定条件的相等查询。
          xorm 中没看到有相关资料。

    11 条回复    2019-09-29 13:21:07 +08:00
    Michaelssss
        1
    Michaelssss  
       2019-09-29 09:40:03 +08:00
    我只认识 Java 的 Orm,Hibernate 采用 Sample,其中 Sample 中 null 和空字符串分开,null 为不查询,非 null 则自动生成 where 字段,换到 go 中也可采用同样的方案
    Immortal
        2
    Immortal  
       2019-09-29 09:43:00 +08:00
    怎么写 sql ?
    _where := db.Where("xxxxx")
    if xxxx {
    _where = _where.Where("xxxx")
    }
    if err := _where.Find(&a).Error;err !=nil{
    return nil,err
    }
    return a,nil
    诺 直接 copy 改(狗头)
    some3284
        3
    some3284  
    OP
       2019-09-29 10:15:04 +08:00
    @Immortal 没有实现模糊查询呀
    imherer
        4
    imherer  
       2019-09-29 10:25:16 +08:00
    直接用 sql 吧,应该会容易些。非要套 gorm 肯定搞复杂了。
    我现在用 gorm 都是简单的查询,复杂的直接写 sql 了
    Immortal
        5
    Immortal  
       2019-09-29 10:35:21 +08:00
    @some3284 你先逻辑里判断字段啊 上层可以需要判断有没有字段的 有就.Where 加一个
    zdt3476
        6
    zdt3476  
       2019-09-29 10:37:27 +08:00
    就像楼上说的,直接写 sql 语句啊,干嘛非得用 orm
    Vegetable
        7
    Vegetable  
       2019-09-29 10:57:02 +08:00   ❤️ 1
    if 有名字{
    cursor =cursor.Where("Name Like %名字%")
    }

    if 有地址 {

    cursor =cursor.Where("address Like %地址%")
    }

    链式调用是可以分开写的.
    Vegetable
        8
    Vegetable  
       2019-09-29 10:58:11 +08:00
    这需求太简单了,这个逻辑必须要会,不能写 sql,因为你写 sql 还是要根据是否有条件进行拼接,和 gorm 的逻辑一摸一样,一个 like 为什么要写 SQL...
    Muninn
        9
    Muninn  
       2019-09-29 11:34:16 +08:00
    这和 go 有啥关系

    而且你这也叫模糊查询……

    人家模糊查询只有一个框
    Leigg
        10
    Leigg  
       2019-09-29 12:03:22 +08:00 via Android
    直接拼 sql,if else 不会?
    some3284
        11
    some3284  
    OP
       2019-09-29 13:21:07 +08:00
    @Vegetable 谢谢了,之前不知道链式调用可以分开写
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1630 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 00:01 · PVG 08:01 · LAX 16:01 · JFK 19:01
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.