Hibernated的sql查询

记录一下学习Hibernate的心得

1.为什么HIbernate会支持原生态的sql查询?

HQL查询语句虽然方便我们查询,但是基于HQL的查询会将查询出来的对象保存到hibernate的缓存当中,如果在我们的一个大型项目中(数据量超过了百万级),这个时候如果使用hibernate的HQL查询的话,会一次将我们查询的对象查询出来后放到缓存中,这个时候会影响我们的效率,所以当在大型项目中使用hibernate时我们的最佳实践就是--使用原生的SQL查询语句,因为通过SQL查询的话,是不会经过hibernate的缓存的。

2.如何使用?

1.返回sql查询的所有字段

  /**
     * 作用:查所有字段
     * 说明:数据库的字段值是保存在一个Object[]数组中的,数组中的每个元素就是查询出来的user50表中的每个字段值
     */

String sql = "select * from user50";
         SQLQuery sqlQuery = session.createSQLQuery(sql);
         List<Object[]> list = sqlQuery.list();
         for (Object[] objects : list) {
            for (Object object : objects) {
                System.out.println(object);
            }
        }

2.返回部分字段

  /**
     * 作用:在所有字段中取部分字段
     * 说明:通过addScalar()方法设置返回的字段和字段对应的类型
     */
String sql = "select *  from user50";
         SQLQuery sqlQuery = session.createSQLQuery(sql);
         List<Object[]> list = sqlQuery.addScalar("id", Hibernate.INTEGER)
                                         .addScalar("name", Hibernate.STRING)
                                         .list();

3.返回一个实体对象

  /**
     * 作用:返回一个实体对象
     * 说明:通过addEntity(),指明实体对象,
     *         这个类必须是实体类,即加了@Entity注解或者在XML中配置了实体类
     *         这时,会首先匹配对象里面的属性是否全部查询出来,如果没有,则报错(如果这个类是实体类)
     *
     * 结果如下:
     * User [userID=1, name=zhangjifeng, age=18, birthday=2016-07-26]
       User [userID=2, name=liujiwang, age=18, birthday=2016-07-26]
     */

 String sql = "select * from user50";
         SQLQuery sqlQuery = session.createSQLQuery(sql);
         List<User> list = sqlQuery.addEntity(User.class).list();
         for (User user : list) {
            System.out.println(user);
        }

4.返回多个实体

   /**
     * 作用:表连接,返回多个实体,
     * 说明:使用占位符:{},解决多张表中有相同的字段:比如user50和order50都有name字段
     */
String sql = "select {u.*}, {o.*}  from user50 u left join order50 o  on u.id=o.user_id";
         SQLQuery sqlQuery = session.createSQLQuery(sql);
         sqlQuery.addEntity("u", User.class);
         sqlQuery.addEntity("o", Order.class);
         List<Object[]> list = sqlQuery.list();
         for (Object[] objects : list) {
             User user = (User)objects[0];
             Order order = (Order)objects[1];
             System.out.println(user);
             System.out.println(order);
        }

5.返回的数据存入非实体对象中

首先需要创建一个数据传输对象,如下:

package com.c50.entity.single;
/**
 * 数据传输对象DTO
 */
public class DTO {

    private Integer id;//用户id
    private Integer price; //订单价格

    public DTO() {
        super();
    }
    public DTO(Integer id, Integer price) {
        super();
        this.id = id;
        this.price = price;
    }
    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public Integer getPrice() {
        return price;
    }

    public void setPrice(Integer price) {
        this.price = price;
    }

    @Override
    public String toString() {
        return "DTO [id=" + id + ", price=" + price + "]";
    }
}

下面是查询方法:

/**
     * 作用:返回不受hibernate管理的实体对象
     * 说明:将多个表中的部分字段查询出来,然后存放到一个javabean对象中,但是我们的这个bean对象又不需要存放到数据库,不需要设置成实体映射对象
     *      这个时候我们往往会创建一个 DTO 的数据传输对象来存放我们要储存的属性,例如定义了一个 DTO对象
     *      通过调用setResultTransformer(Transformers.aliasToBean(DTO.class)) 返回一个DTO对象
     * 输出结果如下:
     * DTO [id=1, price=100]
       DTO [id=1, price=200]
       DTO [id=2, price=300]
     *
     */

    @Test
    public void testSQL6(){
         //获得连接
         Session session = HibernateUtil.getCurrentSession();
         //开启事务
         Transaction tx = session.beginTransaction();
         //业务
         String sql = "select u.id, o.price  from user50 u left join order50 o  on u.id=o.user_id";
         SQLQuery sqlQuery = session.createSQLQuery(sql);
         sqlQuery.addScalar("id", Hibernate.INTEGER);
         sqlQuery.addScalar("price", Hibernate.INTEGER);
         sqlQuery.setResultTransformer(Transformers.aliasToBean(DTO.class));
         List<DTO> list = sqlQuery.list();
         for (DTO userDTO : list) {
            System.out.println(userDTO);
        }
         //提交事务
         tx.commit();
    }
时间: 2024-10-13 23:05:56

Hibernated的sql查询的相关文章

Spring Data JPA原生SQL查询

package com.wanda.cms.dao.repository;import org.springframework.stereotype.Repository;import javax.persistence.EntityManager;import javax.persistence.PersistenceContext;import javax.persistence.Query;import java.math.BigInteger;import java.util.*; /*

oracle新建用户执行sql查询语句出现错误ORA-00942:表或视图不存在

oracle创建新用户后客户端执行SQL查询后出现错误提示如下: 执行查询语句如下: select * from sm_sales_order; ORA-00942:表或视图不存在 创建新用户并指定表空间和临时表空间 CREATE USER xxx IDENTIFIED BY xxxx DEFAULT TABLESPACE LMS TEMPORARY TABLESPACE TEMP; 授予系统权限connect grant connect to xxx; 授予对象权限,只限查询 grant se

提高SQL查询效率

1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如: select id from t where num is null 可以在num上设置默认值0,确保表中num列没有null值,然后这样查询: select id from t where num=0 3.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放

Hibernate 关于执行sql查询语句(转)

原文  http://www.yshjava.cn/post/543.html 主题 SQLHibernate Hibernate对原生SQL查询的支持和控制是通过SQLQuery接口实现的.通过Session接口,我们能够很方便的创建一个SQLQuery(SQLQuery是一个接口,在Hibernate4.2.2之前,默认返回的是SQLQuery的实现类--SQLQueryImpl对象,在下文中出现的SQLQuery如非注明,都是指该子类)对象来进行原生SQL查询: session.creat

笔记:Hibernate SQL 查询

Hibernate 支持使用原生的SQL查询,使用原生SQL查询可以利用某些数据库特性,原生SQL查询也支持将SQL语句放在配置文件中配置,从而提高程序的解耦,命名SQL查询还可以用于调用存储过程. SQL查询是通过SQLQuery接口来表示的,SQLQuery接口是Query接口的子接口,完全可以使用Query接口的方法,SQLQuery增加了二个重载方法 addEntity():将查询到的记录与特定的实体关联 addScalar():江查询的记录关联标量值 执行SQL的步骤如下: 获取Hib

13.hibernate的native sql查询(转自xiaoluo501395377)

hibernate的native sql查询 在我们的hibernate中,除了我们常用的HQL查询以外,还非常好的支持了原生的SQL查询,那么我们既然使用了hibernate,为什么不都采用hibernate推荐的HQL查询语句呢?这是因为HQL查询语句虽然方便我们查询,但是基于HQL的查询会将查询出来的对象保存到hibernate的缓存当中,如果在我们的一个大型项目中(数据量超过了百万级),这个时候如果使用hibernate的HQL查询的话,会一次将我们查询的对象查询出来后放到缓存中,这个时

Hibernate之SQL查询

Hibernate支持使用原生的SQL语句进行查询.使用原生的SQL的好处是:可以利用某些数据库的特性(不同的数据库SQL 语法会有所差异), 将原有的使用JDBC作为持久层技术的应用 ,迁移到使用Hibernate作为持久层技术. 我们知道 使用HQL查询 主要牵涉的是 Query接口,而使用SQL查询 主要牵涉的 是 SQLQuery接口  . 而SQLQuery接口 是 Query接口的子接口. 所以 Query接口中的方法 ,均可以在SQLQuery接口中使用 ,SQLQuery接口还多

Spark编程实现SQL查询的实例

1.Oracle中的SQL select count(1) from a_V_PWYZL_CUSTACCT_PSMIS t where not exists (select 1 from tb_show_multi_question q WHERE q.dqmp_rule_code = '仅比对系统有' and q.dqmp_role_id = '105754659' and q.DQMP_target_id = t.dqmp_mrid) AND NOT EXISTS (select /*+ i

sql查询一天内的where写法,sql写法

sql查询一天内的写法: 1. where createtime BETWEEN (select date_format(now(),'%Y-%m-%d 00:00:00')) and (select date_format(now(),'%Y-%m-%d 23:59:59')) 2. SELECT TO_DAYS(now());SELECT TO_DAYS('2016-07-02 20:50:06'); ========================================附录===