JPA的查询语言—JPQL的命名查询@NamedQuery

http://www.cnblogs.com/luxh/archive/2012/06/01/2531428.html
JPA的命名查询实际上就是给查询语句起个名字,执行查询的时候就是直接使用起的这个名字,避免重复写JPQL语句,使查询在代码中得到更多的重用。我不怎么喜欢使用命名查询,因为我不想把查询语句写在实体中,使得实体看起来变得复杂臃肿。

1、使用@NamedQuery注解在实体类中定义命名查询。

@NamedQuery(name=”findAllUser”,query=”SELECT u FROM User u”)

@NamedQuery中的属性name指定命名查询的名称,query属性指定命名查询的语句。

如果要定义多个命名查询,需要使用@NamedQueries。

@NamedQueries({
@NamedQuery(name=”findAllUser”,query=”SELECT u FROM User u”),
@NamedQuery(name=”findUserWithId”,query=”SELECT u FROM User u WHERE u.id = ?1″),
@NamedQuery(name=”findUserWithName”,query=”SELECT u FROM User u WHERE u.name = :name”)
})

2、定义好命名查询后,可以使用EntityManager的createNamedQuery方法传入命名查询的名称创建查询。例如:createNamedQuery(“findAllUser”);

3、一个简单的例子。

简单的User实体:

Hibernate简单测试

JPA简单的测试: