查询大体流程
//获取SessionFactory
SessionFactory sf = new Configuration().configure().buildSessionFactory();
//通过SessionFactory获取一个session
Session s = sf.openSession();
//开启一个事务
s.beginTransaction();
//三种查询语句以及get和load方法
s.getTransaction().commit();
//关闭session
s.close();
//关闭SessionFactory
sf.close();
HQL(Hibernate Query Language)是hibernate专门用于查询数据的语句,有别于SQL,HQL跟接近于面向对象的思维方式。
比如使用的是类的名字Product,而非表格的名字product_
1. 首先根据hql创建一个Query对象
2. 设置参数(和基1的PreparedStatement不一样,Query是基0的)
3. 通过Query对象的list()方法即返回查询的结果了。
Query q =s.createQuery("from Product p where p.name like ?");
q.setString(0, "%"+name+"%");
List<Product> ps= q.list();
for (Product p : ps) {
System.out.println(p.getName());
使用Criteria 查询数据
1. 通过session的createCriteria创建一个Criteria 对象
2. Criteria.add 增加约束。 在本例中增加一个对name的模糊查询(like)
3. 调用list()方法返回查询结果的集合
Criteria c= s.createCriteria(Product.class)
c.add(Restrictions.like("name", "%"+name+"%"));
List<Product> ps = c.list();
for (Product p : ps) {
System.out.println(p.getName());
标准查询语句:
使用Session的createSQLQuery方法执行标准SQL语句
因为标准SQL语句有可能返回各种各样的结果,比如多表查询,分组统计结果等等。
不能保证其查询结果能够装进一个Product对象中,
所以返回的集合里的每一个元素是一个对象数组。
然后再通过下标把这个对象数组中的数据取出来。
String sql = "select * from product_ p where p.name like '%"+name+"%'";
Query q= s.createSQLQuery(sql);
List<Object[]> list= q.list();
for (Object[] os : list) {
for (Object filed: os) {
System.out.print(filed+"\t");
System.out.println();