addScalar的用法与作用

作用:

1.提高性能

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

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

 

详细讲解如下:

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

 

 
  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()方法:

 

 
  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)。

 

 
  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、指定查询结果中数据列的数据类型

你可能感兴趣的:(addScalar的用法与作用)