gpt4 book ai didi

hibernate - 如何在hibernate查询语言中使用Date函数

转载 作者:行者123 更新时间:2023-12-05 07:44:05 26 4
gpt4 key购买 nike

您好,我想根据日期从数据库中获取记录,我该如何实现呢在数据库中,我有像 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com