java - 如何在 JPQL 语句中使用类型转换?

标签 java jpa openjpa websphere-7

我有两个 Integer数据库中的列(derby 和 db2)。我需要在 JPQL 中将它们彼此分开.

两列的类型都是 Integer如果余数是十进制数,则返回零,例如 0.25变成 0等等,这是可以理解的,因为类型是 int。

SQL例如我可以有这个

select CAST(column1 as decimal(6,2))/CAST(column2 as decimal(6,2))from Sometable;

但是 JPQL 是什么?等价。

一个选项可能是(我还没有尝试过)是有一个 @Transient实体中的方法返回 Decimal 类型并在那里进行计算并将其传递给 JPQL但我宁愿让 SQL做这个工作。


Mysql 不需要在数据库级别进行转换。所以不同 RDBMS 的行为是不同的,这很好。但是 JPQL 应该做什么而不需要使用 native 查询来知道此操作需要强制转换为十进制。

添加方言 <property name="openjpa.jdbc.DBDictionary" value="derby"/>也没修好。

请注意它是 JPA1

最佳答案

你基本上有三个选择。

  1. 使用 poSTLoad,让 java 来做。
  2. 使用第三个类并在 JPQL 的 Select 语句中使用 New Operator 调用构造函数并在调用中你可以管理 将传递给 SQL 的数据类型,但你会得到不止一种 返回一种很好的对象,只需从正确的位置获取正确的对象 数组索引。有关此的更多信息 here .
  3. 像 Idanmo 所说的第三次使用 Native Query。

关于java - 如何在 JPQL 语句中使用类型转换?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10544307/

相关文章:

java - 如何在JPA中混合继承类型

java - WebLogic 11g 中的 JPA 日志记录 (10.3.1)

java - Proguard 返回错误代码 127。请参阅控制台

java - 我如何在克鲁斯卡尔算法中以字符串的形式给出位置(顶点)的名称,更准确地说是城市名称?

java - 使用 setText 获取更多字符串

java - JPA Eclipselink继承: update doesn't work

java - 设置对象时保留对象的值

java - 是否可以再调试 GWT?

hibernate - 使用外键的entitymanager.find()

java - 如果应用程序 srv 隔离级别设置为 READ COMMITTED,是否会发生 OptimisticLockException?