- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们最近将一个项目从使用 Hibernate 4 更新为 Hibernate 5.2,随之而来的是需要更新我们所有的标准以使用 JPA。大多数情况下一切正常,但我有一个查询不再运行。我们正在查询的表上的字段之一是数据库中的 DATE 类型。
当我直接在表上查询时,我得到了日期 - 说它是“2017-04-20”。但是,当我使用 JPA 的 createNativeQuery 在我们的开发服务器上运行相同的查询时,我得到了日期“2017-04-19”
我认为这不是查询的问题,因为我通过 mysql 终端和 java 运行完全相同的查询并得到不同的结果。我运行的查询是在下面的示例中记录的查询。我认为这可能是时区问题,因为我在本地环境中没有这个问题,只是在我的开发服务器上,但在我们更新到新版本的 Hibernate 之前它也不是问题。
public List<ResponseDTO> getDashboardData(String date, Integer page, Integer pageSize, AbstractDashboard dashboard) {
List<ResponseDTO> processed = new ArrayList<ResponseDTO>();
String query = getDashboardQuery(date, dashboard);
logger.info("Dashboard Query: " + query);
List<Object[]> raw = createNativeQuery(query).getResultList();
return raw.stream().map(r->new ResponseDTO(r)).collect(Collectors.toList());
}
还有我的 DTO 对象的构造函数:
public ResponseDTO(Object[] r) {
this.date = ((Date) r[0]).toLocalDate();
System.out.println(this.date.toString());//This date does not match what is in the db.
this.type = (String) r[1];
this.label = (String) r[2];
this.value = (Double) r[3];
}
编辑:
我认为这实际上是 java.sql.Date 类型的问题,因为我尝试在我的开发服务器上打印它,它也返回“2017-04-19”而不是 20 号。当我在 mysql 控制台中运行查询时,我不明白为什么这与结果不匹配,看起来它们对我来说应该是一样的。
最佳答案
好的,我让它工作了。对于它的值(value),这对我来说似乎完全是疯狂的。 “啊哈!”阅读的时刻来了this answer to a different question.
因为是 mysql 驱动程序决定了系统中日期的解析方式。我回滚了我的 mysql 驱动程序,因为它是我更新的软件包之一。突然间一切都按预期进行。
关于java - JPA CreateNativeQuery 返回错误的日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43526066/
我有以下内容,其中包含一个 NativeQuery,我需要在其中设置参数,但有些事情是错误的,因为未设置参数,因此查询是 SELECT movieId, title, genres FROM movi
我有一个使用 EntityManager.createNativeQuery 的应用程序。我们的质量门(Sonar)对此不太满意,并且由于 SQL 注入(inject)的风险而向我显示了一个严重错误。
EntityManager em = OpenJPAUtils.openEntityManager(); String sql="select DISTINCT student.studentId f
如何使用 createNativeQuery 编写 IN 子句? 示例 codeList = "123 ,456"; 然后我得到这样的codeList: CODE IN (:codeList) 但是我
tl;博士 我有一个有效的 SQL 查询,它从 SQL 命令行返回行,但通过 Doctrine 提交时则不会。我认为问题在于我如何设置ResultSetMapper。我读过docs关于 native
我正在使用以下代码通过 hibernate 执行 native SQL 查询: Query zonesQuery = session.createNativeQuery( "S
我在我的项目中使用 Hibernate 和 JPA。我使用下面的代码返回对象列表,但当我在 mysql 中使用 sql 时它返回空列表,它工作正常。 Query query=entityManager
我在 Hibernate 中有一个简单的查找方法: @Override public TblUser findByUsername(String username) { return (Tbl
我正在尝试使用 createNativeQuery 从数据库获取结果集并将其映射到实体对象列表。 当我这样做的时候 List results = this.em.createNativeQuery(q
我需要使用entityManager选择 native 查询。我找到了方法: public Query createNativeQuery(String sqlString, Class result
我尝试使用 Doctrine 选择一百万行,但遇到了一些问题。 首先我尝试使用 ORM 查询来完成此操作,但后来我发现 native 查询更快。(我不需要为此使用 ORM 映射)。 我已经在使用数组水
我在数据库中加入了 2 个具有外键关系的实体,但在代码中没有(将原因留到另一个问题): em.createNativeQuery("SELECT u.* FROM user u JOIN user_c
我们最近将一个项目从使用 Hibernate 4 更新为 Hibernate 5.2,随之而来的是需要更新我们所有的标准以使用 JPA。大多数情况下一切正常,但我有一个查询不再运行。我们正在查询的表上
我想根据一个字段(类型)的值从两个不同的表中检索数据。基本上,如果类型是 2 或 3,则将“subcategory_id”分别关联到类别 2 或类别 3 普通 SQL: SELECT s.id, s.
在 PostgreSQL 数据库中执行的查询正在正确获取记录。但是,当使用 createnativeQuery 实现时,我收到错误 错误 SqlExceptionHelper:131 - 错误:“:”
我想在 entityManager 中使用 createNativeQuery 运行一个 Update 查询。我无法运行它。 我的类(class)结构: class ABC_DAO { List =
使用Java, hibernate 。 我有一个查询 String pixIds = "1,2,3"; String query = "SELECT * FROM comment WHERE PIX_
createNamedNativeQuery 和 createNativeQuery 之间是否有任何与性能相关的特性,因为我们计划对 HQL 查询使用命名查询,并为原生 SQL 查询维护单独的查询文件
EclipseLink 的奇怪行为(Eclipse Persistence Services - 2.1.1.v20100817-r8050),我有一个 false(虚拟/不是数据库中的实际表)实体类
乍一看我有一个简单的问题: entityManager() .createNativeQuery("select count(*) as total, select sum(field) as tot
我是一名优秀的程序员,十分优秀!