Hibernate是一个强力的持久层的框架,他把我们对关系型数据库的操作转换成了面向对象的方式,我们在使用Hibernate在操作数据库时,不仅仅可以用原生的sql语句,还能用Hibernate特有的面相对象的hql语句和无语句的criteria方式进行操作.
原生SQL操作
@Test
public void test4(){
Configuration cf = new Configuration().configure();
SessionFactory sf = cf.buildSessionFactory();
Session session = sf.getCurrentSession();
Transaction transaction = session.beginTransaction();
String sql = "select * from customer";
// 调用createSQLQuery方法传入sql语句查询
// 注:返回值类型是Object[]
SQLQuery sqlQuery = session.createSQLQuery(sql);
// 如果是多条记录就调用list方法
List<Object[]> list = sqlQuery.list();
// 单条记录就调用uniqueResult
// sqlQuery.uniqueResult();
for(int i = 0; i < list.size(); i++){
System.out.println(Arrays.toString(list.get(i)));
}
transaction.commit();
}
因为hibernate是根据实体映射来进行对数据库的操作的,所以在原生sql中我们都填写的数据表的信息而不是实体信息,所以hibernate并不知道你想要使用的实体是哪一个,因此他无法把查询结果封装到相对应的对象中去.
面向对象的hql语句操作
@Test
public void test2(){
Configuration cf = new Configuration().configure();
SessionFactory sf = cf.buildSessionFactory();
Session session = sf.getCurrentSession();
Transaction transaction = session.beginTransaction();
/*
hql操作与sql一样需要书写一个语句
如果查询的是一个表的所有信息,可以省略select *
填写查询列名时,要填写实体中的属性名而不是数据库的列名
from后面写的是实体类的完整类名(如果这个类在项目中唯一,也可以直接写类名)
*/
String hql = "select username from Customer where userid = ?";
// 调用createQuery方法传入hql语句获得返回一个query对象
Query query = session.createQuery(hql);
// 我们可以对这个query进行操作
query.setParameter(0,1l);//设置参数,注:hibernate的参数下标从0开始
// 分页操作时无需写limit,用以下两个方法即可
query.setFirstResult(0);//设置查询结果的开始行
query.setMaxResults(2);//设置查询结果的行数
// 如果查询到的是多条记录,就调用list()方法
List<Customer> list = query.list();
// 如果是单行,就调用uniqueResult
// Customer c1 = (Customer) query.uniqueResult();
System.out.println(list);
transaction.commit();
}
无语句的Criterial操作
@Test
public void test3(){
Configuration cf = new Configuration().configure();
SessionFactory sf = cf.buildSessionFactory();
Session session = sf.getCurrentSession();
Transaction transaction = session.beginTransaction();
// 传入要查询的实体类就会查询到这个类对应的表的记录
Criteria criteria = session.createCriteria(Customer.class);
// 查询的条件需要在add()方法中Restrictions这个类的方法去加入
criteria.add(Restrictions.eq("username","老王"));//效果等同于where username = 老王
criteria.addOrder(Order.asc("userid"));//设置查询结果的排列顺序,等同于order by useri
// 分页操作时无需写limit,用以下两个方法即可
// query.setFirstResult(0);//设置查询结果的开始行
// query.setMaxResults(2);//设置查询结果的行数
criteria.setProjection(Projections.rowCount());//聚合查询,等通过 select count(*)
// 如果查询到的是多条记录,就调用list()方法
List<Customer> list = criteria.list();
System.out.println(list);
transaction.commit();
}
以上的三种方法都有自己特有的优势,在使用hibernate操作数据库时应根据情况选择使用.
单表操作时建议使用Criterial,单表操作起来非常简单,多表使用的话就有一点麻烦了.
单表和简单的多表可以使用hql,复杂的多表用起来也是很麻烦的.
复杂多表还是乖乖用sql吧.