作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
您好,我想根据日期从数据库中获取记录,我该如何实现呢在数据库中,我有像 start_date 这样的数据类型为 datetime 的列,在模型类中我有像
这样的数据成员public class Records {
private Date startDate
// getters and setters
}
正在尝试编写如下查询
String hql = "from Records where DATE(startDate)=? ";
Query query = session.createQuery(hql);
query.setParameter(0, getStartDate());
最佳答案
您的问题中有很多事情不清楚。但是,尝试将 TemporalType.DATE 添加到您的查询中,例如:
.. query.setParameter(0, getStartDate(), TemporalType.DATE);
基本上,JPA 需要知道您正在使用日期字段过滤记录。如果我可以使用更详细的示例进行演示:如果您的实体类是 Record 并且@Id 是字段 startDate,那么:
@Entity
@NamedQuery(name="Record.findByStartDate",
query="SELECT e FROM Record e" // here returning the whole entity
+ " WHERE e.startDate = :startDate")
@Table(name="records")
public class Record implements Serializable {
@Id
@Column(name="startDate")
@Temporal(TemporalType.DATE)
private Date startDate;
...
}
搜索查询方法如下:
public Record findByStartDate (Date startDate) {
try {
return (Record) em.createNamedQuery("Record.findByStartDate")
.setParameter("startDate", startDate, TemporalType.DATE)
.getSingleResult();
} catch (NoResultException e) {
return null;
}
}
关于hibernate - 如何在hibernate查询语言中使用Date函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43155688/
我是一名优秀的程序员,十分优秀!