例:页面两个查询框,分别是姓名,地址,模糊查询时,可能只有一个查询框有值,也可能两个都有值。
问:这该怎么写 sql ?
备注:目前看过:gorm 中只支持固定条件,必定有值的模糊查询;和不定有值,不定条件的相等查询。
xorm 中没看到有相关资料。
1
Michaelssss 2019-09-29 09:40:03 +08:00
我只认识 Java 的 Orm,Hibernate 采用 Sample,其中 Sample 中 null 和空字符串分开,null 为不查询,非 null 则自动生成 where 字段,换到 go 中也可采用同样的方案
|
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 改(狗头) |
4
imherer 2019-09-29 10:25:16 +08:00
直接用 sql 吧,应该会容易些。非要套 gorm 肯定搞复杂了。
我现在用 gorm 都是简单的查询,复杂的直接写 sql 了 |
6
zdt3476 2019-09-29 10:37:27 +08:00
就像楼上说的,直接写 sql 语句啊,干嘛非得用 orm
|
7
Vegetable 2019-09-29 10:57:02 +08:00 1
if 有名字{
cursor =cursor.Where("Name Like %名字%") } if 有地址 { cursor =cursor.Where("address Like %地址%") } 链式调用是可以分开写的. |
8
Vegetable 2019-09-29 10:58:11 +08:00
这需求太简单了,这个逻辑必须要会,不能写 sql,因为你写 sql 还是要根据是否有条件进行拼接,和 gorm 的逻辑一摸一样,一个 like 为什么要写 SQL...
|
9
Muninn 2019-09-29 11:34:16 +08:00
这和 go 有啥关系
而且你这也叫模糊查询…… 人家模糊查询只有一个框 |
10
Leigg 2019-09-29 12:03:22 +08:00 via Android
直接拼 sql,if else 不会?
|