Hibernate的sql,hql,criteria的简单使用

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吧.

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值