1)     To consolidate all the queries of an Entity class. Putting all queries as annotations
at Entity level.
at Entity level.
    2)     To write queries at Entity level
@NamedQuery(name, actual query)
@NamedNativeQuery(name,actual SQL query)
In NamedNativeQuery , we can actually provide SQL type query as an argument.
HibernateNamedQuery.java
public class HibernateNamedQuery {
     public static void main(String[] args) {
         SessionFactory sessionFactory = new                                     Configuration().configure().buildSessionFactory();
           Session session = sessionFactory.openSession();
           session.beginTransaction();
           Query query = session.getNamedQuery("Person.byId");
           query.setLong(0,5);
           List<Person> list = (List<Person>) query.list();
           for(Person p: list)
                System.out.println(p.getName());
           Query query1 = session.getNamedQuery("Person.byName");
           query1.setString(0,"Person 1");
           List<Person> list1 = (List<Person>) query1.list();
           for(Person p: list1)
                System.out.println(p.getName());
           session.getTransaction().commit();
           session.close();
     }
}
Person.java
@Entity(name="PERSON")
@NamedQuery(name="Person.byId",query="from PERSON where id=?")
@NamedNativeQuery(name="Person.byName",query="Select * from Person where Name=?",resultClass=Person.class)
public class Person implements java.io.Serializable{
      private static final long serialVersionUID = 1L;
      private String name;
      @Id
      @GeneratedValue(strategy=GenerationType.AUTO)
      private long id;
      public String getName() {
            return name;
      }
      public void setName(String name) {
            this.name = name;
      }
      public long getId() {
            return id;
      }
      public void setId(long id) {
            this.id = id;
      }
}
Output:
Hibernate: select person0_.id as id0_, person0_.name as name0_ from PERSON person0_ where person0_.id=?
Person 5
Hibernate: Select * from Person where Name=?
Person 1
No comments:
Post a Comment