栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何在HQL中使用一个类似的运算符在多列中进行搜索(Hibernate SQL)

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何在HQL中使用一个类似的运算符在多列中进行搜索(Hibernate SQL)

您可以使用 REGEX 解决问题,例如:

REGEXP_LIKE('Hello world', 'Hello', 'mars') = 1

因此,您可以替换查询:

select ... where c.clientId = ? and  c.vehicleReg1 like ? or c.vehicleReg2 like ?

通过在这里使用此查询:

SELECT ... WHERe c.clientId = ? and REGEXP_LIKE(?, c.vehicleReg1, c.vehicleReg2) = 1-- -------------------------------------^^

这意味着如果您的值

?
是like
c.vehicleReg1
c.vehicleReg2
返回
1
,则匹配错误


注意

@ mm759,由于程序的编码和结构方式…它仅传递2个参数(一个用于clientId,一个用于多个vehicleReg列)

您可以在查询的多个位置使用相同的参数,如下所示:

q = getEntityManager().createNamedQuery("select ... where c.clientId = :par1 and  c.vehicleReg1 like :par2 or c.vehicleReg2 like :par2");//-------------------------------^^----------------------------^^--------------------------^^q.setParamettre("par1", "value1");q.setParamettre("par2", "value2");


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/506963.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号