Hibernate查询方式&抓取策略

Hibernate的查询方式

1、OID查询

hibernate根据对象的OID(主键)进行检索

  使用get方法

Customer customer=session.get(Customer.class,1l);

  使用load方法

Customer customer=session.load(Customer.class,1l);

2、对象导航检索

hibernate根据一个已经查询到的对象,获得其关联的对象的一种查询方式

LinkMan linkMan=Session.get(LinkMan.class,1l);
Customer customer=linkMan.getCustomer();

3、HQL检索

Hibernate Query Language 的查询语言,是一种面向对象的方式的查询语言,语法类似于SQL。通过session.createQuery()用于接收一个HQL进行查询

HQL的简单查询

	/*
* HQL简单查询
* */
public void demo2() {
Session session=HibernateUtils.openSession();
Transaction transaction=session.beginTransaction();
Query query=session.createQuery("from Customer");
List<Customer> list=query.list();
for(Customer customer:list)
System.out.println(customer.toString());
transaction.commit();
}

HQL的别名查询

	/*
* HQL简单查询
* */
public void demo2() {
Session session=HibernateUtils.openSession();
Transaction transaction=session.beginTransaction();
Query query=session.createQuery("from Customer c");
List<Customer> list=query.list();
for(Customer customer:list)
System.out.println(customer.toString());
transaction.commit();
}

HQL的投影查询

查询对象的某个或某些属性

	public void demo6() {
Session session=HibernateUtils.openSession();
Transaction transaction=session.beginTransaction();
List<Object> list=session.createQuery("select c.cust_name from Customer c").list();
for(Object object:list)
System.out.println(object);
transaction.commit();
}

 

上一篇:关于c++中方法名前面的双冒号


下一篇:C语言第六次博客作业--数据类型