【转】addScalar的用法与作用

作用:

1.提高性能

2.指定要返回哪几个字段,没指定的不返回(主要用于select *查询全部)

3.也可指定返回字段的具体类型


详细讲解如下:

最基本的SQL查询就是获得一个标量的列表:

[java]  view plain  copy
  1. session.createSQLQuery("select * from person_inf").list();    
  2.     
  3. session.createSQLQuery("select id,name,age from person_inf").list();  
         它们都将返回一个Object数组组成的List,数组每个元素都是person_inf表的一个字段值。 Hibernate会使用ResultSetMetadata来判定返回的标量值的实际顺序和类 型。 
         但是在JDBC中 过多的使用ResultSetMetadata会降低程序的性能 。所以为了过多的避免使用ResultSetMetadata或者为了指定更加明确的返回值类型,我们可以使用addScalar()方法:

[java]  view plain  copy
  1. session.createSQLQuery("select * from person_inf")    
  2.     
  3. .addScalar("name",StandardBasicTypes.STRING)    
  4.     
  5. .addScalar("age",StandardBasicTypes.INT)  
  6. .list();  

  这个查询指定了: 
         1、SQL查询字符串。 
         2、要返回的字段和类型。 
         它仍然会返回Object数组,但是此时不再使用ResultSetMetdata,而是明确的将name和age按照String和int类型从resultset中取出。同时,也指明了就算query是使用*来查询的,可能获得超过列出的这两个字段,也 仅仅会返回这两个字段 。 
         如果仅仅只需要选出某个字段的值,而不需要明确指定该字段的数据类型,则可以使用addScalar(String columnAlias)。

[java]  view plain  copy
  1. public void scalarQuery(){    
  2.         Session session = HibernateUtil.getSession();    
  3.         Transaction tx = session.beginTransaction();    
  4.         String sql = "select * from person_inf";    
  5.         List list = session.createSQLQuery(sql).    
  6.                     addScalar("person_id",StandardBasicTypes.INTEGER).    
  7.                     addScalar("name", StandardBasicTypes.STRING).    
  8.                     addScalar("age",StandardBasicTypes.INTEGER).list();    
  9.         for(Iterator iterator = list.iterator();iterator.hasNext();){    
  10.             //每个集合元素都是一个数组,数组元素师person_id,person_name,person_age三列值    
  11.             Object[] objects = (Object[]) iterator.next();    
  12.             System.out.println("id="+objects[0]);    
  13.             System.out.println("name="+objects[1]);    
  14.             System.out.println("age="+objects[2]);    
  15.             System.out.println("----------------------------");    
  16.         }    
  17.         tx.commit();    
  18.         session.close();    
  19.     }  

   从上面可以看出。标量查询中addScalar()方法有两个作用: 
         1、指定查询结果包含哪些数据列---没有被addScalar选出的列将不会包含在查询结果中。 

         2、指定查询结果中数据列的数据类型


标量查询和实体查询:

实体查询与标量查询不同的是:标量查询只是返回一些标量的结果集,而实体查询返回的是数据表中全部数据列。

实体查询的两个条件:
1:查询返回某个数据表的全部数据列,要选出全部数据列(可以在SQL字符串中使用*来表示返回所有列)

2:该数据表有对应的持久化类映射



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值