作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有两个 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
最佳答案
你基本上有三个选择。
关于java - 如何在 JPQL 语句中使用类型转换?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10544307/
我是一名优秀的程序员,十分优秀!