zoukankan      html  css  js  c++  java
  • Hibernate运行原生sql并将查询的结果转化为对象

    原生SQL查询执行的控制是通过SQLQuery接口进行的,通过执行Session.createSQLQuery()获取这个接口。下面来描述如何使用这个API进行查询。
    标量查询(Scalar queries)
    最基本的SQL查询就是获得一个标量(数值)的列表。
    sess.createSQLQuery("SELECT * FROM CATS").list();
    sess.createSQLQuery("SELECT ID, NAME, BIRTHDATE FROM CATS").list();
    它们都将返回一个Object数组(Object[])组成的List,数组每个元素都是CATS表的一个字段值。Hibernate会使用ResultSetMetadata来判定返回的标量值的实际顺序和类型。
    如果要避免过多的使用ResultSetMetadata,或者只是为了更加明确的指名返回值,可以使用addScalar()。

    sess.createSQLQuery("SELECT * FROM CATS")
            .addScalar("ID", StandardBasicTypes.LONG)
            .addScalar("NAME", StandardBasicTypes.STRING)
            .addScalar("BIRTHDATE", StandardBasicTypes.DATE)
    这个查询指定了:
    SQL查询字符串
    要返回的字段和类型


    注意:在query中加上 setResultTransformer(Transformers.aliasToBean(clazz));
    这里的clazz表示的是传入的自定义的bean.class ,这里的bean是自己封装的,不需要有映射文件,如果使用query = getSession().createSQLQuery(sql).addEntity(clazz); 需要bean具有映射文件
    query = getSession().createSQLQuery(sql).setResultTransformer(Transformers.aliasToBean(clazz));

    当对象的属性类型与查询出来的字段类型不一致时,可以通过addScalar("smallclass_id", StandardBasicTypes.INTEGER)  这个方法进行设置,第一个参数是字段名称,第二个参数是对象的类型,但是:当使用了addScalar时,所有的查询的字段都需要重新设置类型,否则不设置的字段查询出来值为null,例如:
    Query query=getCurrent().createSQLQuery(sql).addScalar("smallclass_id", StandardBasicTypes.INTEGER).addScalar("smallclassrights",StandardBasicTypes.INTEGER).setResultTransformer(new AliasToBeanResultTransformer(SmallClass.class))

    封装到SmallClass中的属性只有smallclass_id和smallclassrights两个字段是有值的,如果存在第三个属性,则封装到对象中值为null
    ---------------------
    作者:飞天武者
    来源:CSDN
    原文:https://blog.csdn.net/hhua5230/article/details/79923678
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    maven打包将依赖和配置外置的配置方式
    AngularJS零碎总结
    Python零碎总结
    win10 平台 elasticsearch 与 elasticsearch-head 的安装
    DDD中的分层架构
    读书有感--------软件的设计原则
    DDD初探
    HTTP could not register URL http://+:86/. 设置VS默认以管理员权限打开
    .net 实战 根据configuration选项生成不同的config文件
    asp.net mvc5轻松实现插件式开发
  • 原文地址:https://www.cnblogs.com/zzt-lovelinlin/p/10736075.html
Copyright © 2011-2022 走看看