zoukankan      html  css  js  c++  java
  • SQL查询(笔记2——实体查询)

    SQL查询(笔记2——实体查询)   

          二、实体查询

           如果查询返回了某个数据表的全部数据列,且该数据表有对应的持久化类映射,我们就把查询结果转换成实体查询。将查询结果转换成实体,可以使用SQLQuery提供的多个重载addEntity()方法。

           String sqlString = "select * from enrolment where year=:year";

           List l = session.createSQLQuery (sqlString)

                       //指定查询的记录行转换成Enrolment实体

                       .addEntity(Enrolment.class)

                       //为SQL字符串的参数设置值

                       .setInteger("year",2005)

                       .list();

    注意:使用原生SQL查询时,程序必须选出所有数据列才可转换成持久化实体。假设实体在映射时有一个<many-to-one/>管来指向另一个实体,则SQL查询中必须返回该<many-to-one/>映射的外键列,否则将导致抛出"column not found"异常。最简单的做法是,在SQL字符串中使用(*)来表示返回所有列。

    Hibernate支持将查询结果转换成多个实体,如果要将查询结果转换成多个实体,则SQL字符串中应为不同数据表指定不同别名,并调用addEntity(String alias, Class entityClass)方法将不同数据表转换成不同实体。程序片段如下:

    String sqlString = "select s.*,e.*,c.* from student s,enrolment e,course c where s.student_id = e.student_id and e.course_code = c.course_code ";

    List l = session.createSQLQuery(sqlString)

               .addEntity("s",Student.class)

               .addEntity("e",Enrolment.class)

               .addEntity("c",Course.class)

    三、将查询加过转换成非持久化实体

    只要该JavaBean为这些数据列提供了对应的getter和setter方法即可。

    Query接口提供了一个setResultTransformer()方法,该方法接受一个Transformers对象,通过使用该对象的方法(如aliasToBean()方法)即可把查询到的结果集转换成JavaBean集。

  • 相关阅读:
    主流负载均衡器LVS、Nginx、HAProxy介绍
    shell脚本加密软件shc
    Linux系统安全配置相关
    Linux系统split对tar文件进行分片和压缩
    kubernetes组件详解和创建POD流程
    构建RPM之SPEC详解
    Python推荐系统框架:RecQ
    Python常用库-Psutil
    使用NLP从文章中自动提取关键字
    模糊字符串匹配:FuzzyWuzzy
  • 原文地址:https://www.cnblogs.com/Rozdy/p/4380006.html
Copyright © 2011-2022 走看看