JPA,Hibernate和Spring Data:在MS SQL服务器上的where子句中将字符串转换为数字

问题描述 投票:0回答:1

我正在做一个网络项目。它使用Spring(5.0.2.RELEASE),Hibernate(5.2.12.Final)和Spring Data(2.0.2.RELEASE)。这些是最新版本,因此我可以使用JPA 2.1。该网站在Windows和MS SQL Server 2014 Enterprise上运行。

我有一个有nvarchar字段的类

Class1 {
    ....
    @Column(columnDefinition = "NVARCHAR(20)")
    private String textOrNumber = null;
    ...
}

我能够在MS SQL Server Management Studio(一个与Java无关的Windows程序)中成功地对数据库运行以下本机查询。

SELECT c.textOrNumber FROM Class1 c WHERE ISNUMERIC(c.textOrNumber ) = 1 
   AND CAST(c.textOrNumber AS DECIMAL(17,2)) > 0

上面的查询能够找到textOrNumber上的值是大于0的数字(整数或小数)的记录。

这是我在Java中所拥有的:

Query q = em.createQuery("SELECT c FROM Class1 c WHERE ISNUMERIC(c.textOrNumber ) = 1 "
+ "AND CAST(c.textOrNumber AS DECIMAL(17,2))");
return q.getResultList();

这是错误消息:

Caused by: 
org.hibernate.hql.internal.ast.QuerySyntaxException: expecting CLOSE, found '(' near line 1, column 122 [SELECT c FROM mytest.Class1 c WHERE ISNUMERIC(c.textOrNumber) = 1 AND CAST(c.textOrNumber AS DECIMAL(17,2)) > 2]
    at org.hibernate.hql.internal.ast.QuerySyntaxException.convert(QuerySyntaxException.java:74)
    at org.hibernate.hql.internal.ast.ErrorCounter.throwQueryException(ErrorCounter.java:91)
    at org.hibernate.hql.internal.ast.QueryTranslatorImpl.parse(QueryTranslatorImpl.java:291)
    at org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:186)
    at org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:141)
    at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:115)
    at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:77)
    at org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:153)
    at org.hibernate.internal.AbstractSharedSessionContract.getQueryPlan(AbstractSharedSessionContract.java:553)
    at org.hibernate.internal.AbstractSharedSessionContract.createQuery(AbstractSharedSessionContract.java:662)
    at org.hibernate.internal.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:23)
    at sun.reflect.GeneratedMethodAccessor37.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)

我如何通过使用CAST或其他东西来解决这个问题?

附加信息:

这在JPA中运行没有任何问题(它在textOrNumber字段中找到带有数字的记录):

SELECT c FROM Class1 c WHERE ISNUMERIC(c.textOrNumber ) = 1  
hibernate jpa spring-data spring-data-jpa jpa-2.0
1个回答
0
投票

我通过以下方式使用MS SQL Server中的CONVERT解决了这个问题:

em.createQuery("SELECT c FROM Class1 c WHERE ISNUMERIC(c.textAndNumber) = 1 AND
    CONVERT(DECIMAL(17,2), c.textAndNumber) > 3");

如果有人可以进行CAST工作,我会选择他的帖子作为答案。

希望这有助于其他人。

© www.soinside.com 2019 - 2024. All rights reserved.