我正尝试在Hibernate SQL查询中使用COLLATE语句,但它无法识别该语句。
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会返回这个异常:
- 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中它工作得很好。
发布于 2013-07-17 04:56:03
它可以在条件查询中指定。请参阅this answer
发布于 2021-09-17 12:10:38
而不是在HQL中拥有:
String hql = "SELECT e" +
" FROM EntityJPA e" +
" WHERE e.mycolumn COLLATE 'utf8_bin' = 'VALUE'"
Query query = entityManager.createQuery(hql);您可以像这样使用原生查询
String sql = "SELECT t" +
" FROM entity_table t" +
" WHERE t.mycolumn COLLATE 'utf8_bin' = 'VALUE'" 并将其作为原生查询执行:
Query query = entityManager.createNativeQuery(sql);这是更简单的解决方案,记住原生查询会创建对目标数据库的SQL语言的依赖(在我们的例子中是mySQL)。
对于我们来说,这仍然是可以接受的,因为使用不同的DB引擎的可能性非常低。
https://stackoverflow.com/questions/13160476
复制相似问题