zoukankan      html  css  js  c++  java
  • Hibernate API的使用(Query、Criteria、SQLQuery对象)

    Query对象

    我们使用Query对象不需要编写SQL语句,但是得写HQL语句。

    HQLHibernate Query LanguageHibernate提供的查询语言,和SQL语句很相似。

    HQLSQL的区别:

      使用SQL操作的是表和表字段;  

      使用HQL操作的是实体类和实体类的属性;

    查询所有记录的HQLfrom 实体类名称

    Query对象的使用:

    步骤一:创建Query对象;

    步骤二:调用Query对象里面的方法得到结果;

    代码演示:

    @Test

    //使用Query对象

    public void testQuery(){

    SessionFactory sessionFactory = null;

    Session session = null;

    Transaction transaction = null;

    try {

    sessionFactory = HibernateUtil.getSessionFactory();

    session = sessionFactory.openSession();

    //开启事务

    transaction = session.beginTransaction();

    //1 创建Query对象

    //编写HQL语句

    Query query = session.createQuery("from User");

    //2 调用Query对象里面的方法得到结果

    List<User> userList = query.list();

    for (User user : userList) {

    System.out.println(user);

    }

    //提交事务

    transaction.commit();

    } catch (Exception e) {

    // TODO: handle exception

    e.printStackTrace();

    transaction.rollback();

    }finally{

    session.close();

    sessionFactory.close();

    }

    }

    Hibernate:

        select

            user0_.ID as ID1_0_,

            user0_.USERNAME as USERNAME2_0_,

            user0_.PASSWORD as PASSWORD3_0_,

            user0_.ADDRESS as ADDRESS4_0_

        from

            USER user0_

    User [id=1, username=yyyyyy, password=null, address=null]

    User [id=3, username=uc, password=up, address=tw]

    User [id=4, username=qqqqq, password=111111, address=shanxi]

    User [id=7, username=nihao111, password=nihaopwd111, address=U.S.A111]

    Criteria对象

    说明:使用这个对象也可以实现查询操作,但是使用这个对象的时候,不需要编写HQL语句,直接调用方法就可以了。

    使用过程和Query很相似:

    过程如下:

    • 创建Criteria对象;
    • 调用对象里面的方法得到结果;

    代码演示:

    //1 创建Criteria对象

    Criteria criteria = session.createCriteria(User.class);

    //2 调用Query对象里面的方法得到结果

    List<User> userList = criteria.list();

    for (User user : userList) {

    System.out.println(user);

    }

    Hibernate:

        select

            this_.ID as ID1_0_0_,

            this_.USERNAME as USERNAME2_0_0_,

            this_.PASSWORD as PASSWORD3_0_0_,

            this_.ADDRESS as ADDRESS4_0_0_

        from

            USER this_

    User [id=1, username=yyyyyy, password=null, address=null]

    User [id=3, username=uc, password=up, address=tw]

    User [id=4, username=qqqqq, password=111111, address=shanxi]

    User [id=7, username=nihao111, password=nihaopwd111, address=U.S.A111]

    SQLQuery对象

    使用Hibernate的时候,也可以调用底层SQL语句来实现。

    实现过程:

    1、创建SQLQuery对象;

    2、调用对象的方法实现;

    代码演示:

    SQLQuery sqlQuery = session.createSQLQuery("select * from user");

    //2 调用Query对象里面的方法得到结果

    //返回的list集合,默认是数组结构

    List<Object[]> userList = sqlQuery.list();

    for (Object[] userObject : userList) {

    System.out.println(Arrays.toString(userObject));

    }

    Hibernate:

        select

            *

        from

            user

    [1, yyyyyy, null, null]

    [3, uc, up, tw]

    [4, qqqqq, 111111, shanxi]

    [7, nihao111, nihaopwd111, U.S.A111]

    解决问题:返回list中的每部分是对象形式

    //1 创建SQLQuery对象

    SQLQuery sqlQuery = session.createSQLQuery("select * from user");

    sqlQuery.addEntity(User.class);

    //2 调用Query对象里面的方法得到结果

    //返回的list集合,默认是数组结构

    List<User> userList = sqlQuery.list();

    for (User userObject : userList) {

    System.out.println(userObject);

    }

    Hibernate:

        select

            *

        from

            user

    User [id=1, username=yyyyyy, password=null, address=null]

    User [id=3, username=uc, password=up, address=tw]

    User [id=4, username=qqqqq, password=111111, address=shanxi]

    User [id=7, username=nihao111, password=nihaopwd111, address=U.S.A111]

  • 相关阅读:
    【STSRM12】整除
    【STSRM12】夏令营
    【BZOJ】1954: Pku3764 The xor-longest Path
    Faster-rcnn实现目标检测
    反向传播算法的理解
    人工智能发展的看法
    FCN的理解
    卷积神经网络的部分知识理解
    不常见算法的介绍
    如何对模型进行优化
  • 原文地址:https://www.cnblogs.com/angelye/p/7366277.html
Copyright © 2011-2022 走看看