首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Hibernate查询中使用COLLATE

如何在Hibernate查询中使用COLLATE
EN

Stack Overflow用户
提问于 2012-10-31 22:41:45
回答 2查看 8.3K关注 0票数 3

我正尝试在Hibernate SQL查询中使用COLLATE语句,但它无法识别该语句。

代码语言:javascript
复制
CONSULTA: FROM Articulos WHERE activo=0 
              and (codigodearticulo like '%CIN EMB%' COLLATE='Modern_Spanish_CI_AI'
              or descripcion like '%CIN EMB%' COLLATE='Modern_Spanish_CI_AI'  
              or descripcionadicional like '%CIN EMB%' COLLATE='Modern_Spanish_CI_AI' )
              and codigodelinea in
              (select CODIGODELINEA from Lineas where CATAUTOPARTES='1')

当应用程序编译时,Hibernate会返回这个异常:

代码语言:javascript
复制
- line 1:107: unexpected token: COLLATE
- line 1:107: unexpected token: COLLATE
- line 1:107: unexpected token: COLLATE
- Error hibernate: unexpected token: COLLATE near line 1, column 107

我找不到问题,在MSSQL Server中它工作得很好。

EN

回答 2

Stack Overflow用户

发布于 2013-07-17 04:56:03

它可以在条件查询中指定。请参阅this answer

票数 2
EN

Stack Overflow用户

发布于 2021-09-17 12:10:38

而不是在HQL中拥有:

代码语言:javascript
复制
String hql = "SELECT e" +
    " FROM EntityJPA e" +
    " WHERE e.mycolumn COLLATE 'utf8_bin' = 'VALUE'"

Query query = entityManager.createQuery(hql);

您可以像这样使用原生查询

代码语言:javascript
复制
String sql = "SELECT t" +
    " FROM entity_table t" +
    " WHERE t.mycolumn COLLATE 'utf8_bin' = 'VALUE'" 

并将其作为原生查询执行:

代码语言:javascript
复制
Query query = entityManager.createNativeQuery(sql);

这是更简单的解决方案,记住原生查询会创建对目标数据库的SQL语言的依赖(在我们的例子中是mySQL)。

对于我们来说,这仍然是可以接受的,因为使用不同的DB引擎的可能性非常低。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13160476

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档