java-命名查询中的休眠错误

我正在尝试从表中提取信息,其中当前日期在任何给定月份的第一天和最后一天之间.

我收到运行时错误“命名查询中的错误:Department.byDate”

我正在向您提供我认为可能导致问题的代码,如果需要任何其他代码,请在评论中告知我.

我的命名查询如下所示:

@NamedQuery(name="Department.byDate", query="select * from department where date >= :first AND date <= :last")

我在DAO中以一种类似于以下方式的方法使用此命名查询:

public List<Department> getRecords(Date dateFirst, Date dateLast){
    Session session= sessionFactory.openSession();
    session.beginTransaction();

    Query query = session.getNamedQuery("Department.byDate");
    query.setDate("first", dateFirst);
    query.setDate("last", dateLast);

    List<Department> depList = (List<Department>)query.list();

    session.getTransaction().commit();
    session.close();

    return depList;
}

我获取月份的第一天和最后几天的方法如下:

Calendar first = Calendar.getInstance();
first.set(Calendar.getInstance().get(Calendar.YEAR), Calendar.getInstance().get(Calendar.MONTH), Calendar.getInstance().getActualMinimum(Calendar.DAY_OF_MONTH));
Date dateFirst = first.getTime();

Calendar last = Calendar.getInstance();
first.set(Calendar.getInstance().get(Calendar.YEAR), Calendar.getInstance().get(Calendar.MONTH), Calendar.getInstance().getActualMaximum(Calendar.DAY_OF_MONTH));
Date dateLast = last.getTime();

解决方法:

>在HQL / JPQL中,您正在使用实体及其属性,因此*字符没有意义.
> HQL / JPQL类和属性名称为case sensitive.

您应该通过以下方式编写查询:

select d from Department d where d.date >= :first AND d.date <= :last
上一篇:mybatis-generator.xml文件


下一篇:SpringMVC系列(四)使用 POJO 对象绑定请求参数