如何在JPQL中创建“findBy Date”命名查询?

问题描述 投票:1回答:1

我正在尝试为Web服务创建一个@NamedQuery,以便可以返回具有给定出生日期的客户列表。

GlassFish报告以下错误:

异常描述:编译问题[SELECT c FROM Customer c WHERE c.dob = to_date(:dob,'dd-Mon-yyyy')]。 [38,45]在FROM子句中没有定义标识变量'to_date'。

@NamedQuery(name = "Customer.findByDob", query = "SELECT c FROM Customer c WHERE c.dob = to_date(:dob, 'dd-Mon-yyyy')")

@GET
    @Path("findByDob/{dob}")
    @Produces({"application/json"})
    public List<Customer> findByDob(@PathParam("dob") String dob) {
        Query q = em.createNamedQuery("Customer.findByDob");
        q.setParameter("dob", dob);
        return q.getResultList(); 
}

任何反馈都非常感谢。

java glassfish jpql derby
1个回答
1
投票

您可以在实体管理器中委派从Date到String数据库格式的转换。这样的东西应该有效:

@NamedQuery(name = "Customer.findByDob", query = "SELECT c FROM Customer c WHERE c.dob = :dob")

        @GET
        @Path("findByDob/{dob}")
        @Produces({"application/json"})
        public List<Customer> findByDob(@PathParam("dob") String dob) {
            SimpleDateFormat sdf = new SimpleDateFormat("dd-Mon-yyyy");
            Date dobDate = sdf.parse(dob); //Create a new Java Date object. 

            Query q = em.createNamedQuery("Customer.findByDob");
            q.setParameter("dob", dobDate); //The entity manager will transform the Date to query needs.
            return q.getResultList(); 
    }
© www.soinside.com 2019 - 2024. All rights reserved.