zoukankan      html  css  js  c++  java
  • atitit. orm框架的hibernate 使用SQLQuery createSQLQuery addEntity

    atitit. orm框架的hibernate 使用SQLQuery createSQLQuery addEntity

    1. addEntity
    对原生SQL查询运行的控制是通过SQLQuery接口进行的。通过运行Session.createSQLQuery()获取这个接口。最简单的情况下,我们能够採用下面形式:

    List cats = sess.createSQLQuery( " select * from cats " ).addEntity(Cat. class ).list(); 

    作者:: 老哇的爪子 Attilax 艾龙,  EMAIL:1466519819@qq.com

    转载请注明来源: http://blog.csdn.net/attilax

    2. addEntity  占位符 别名

    这里,结果集字段名被如果为与映射文件里指明的字段名相同。对于连接了多个表的查询。这就可能造成问题,由于可能在多个表中出现相同名字的字段。

    以下的方法就能够避免字段名反复的问题:

    List cats = sess.createSQLQuery( " select {cat.*} from cats cat " ).addEntity( " cat " , Cat. class ).list(); 

    这个查询指定了:

    SQL查询语句。它带一个占位符,能够让Hibernate使用字段的别名.

    查询返回的实体,和它的SQL表的别名.

    addEntity()方法将SQL表的别名和实体类联系起来。而且确定查询结果集的形态。

    3. addJoin()方法能够被用于加载其它的实体和集合的关联.

    List cats = sess.createSQLQuery(
    " select {cat.*}, {kitten.*} from cats cat, cats kitten where kitten.mother = cat.id " )
    .addEntity( " cat " , Cat. class )
    .addJoin( " kitten " , " cat.kittens " )
    .list(); 

    4. 參考

    hibernatecreateSQLQueryaddEntity()setResultTransformer()方法 正走向大牛的菜鸟 - ITeye技术站点.htm

  • 相关阅读:
    Java实现 蓝桥杯 算法训练 画图(暴力)
    Java实现 蓝桥杯 算法训练 画图(暴力)
    Java实现 蓝桥杯 算法训练 相邻数对(暴力)
    Java实现 蓝桥杯 算法训练 相邻数对(暴力)
    Java实现 蓝桥杯 算法训练 相邻数对(暴力)
    Java实现 蓝桥杯 算法训练 Cowboys
    Java实现 蓝桥杯 算法训练 Cowboys
    55. Jump Game
    54. Spiral Matrix
    50. Pow(x, n)
  • 原文地址:https://www.cnblogs.com/jzssuanfa/p/7402889.html
Copyright © 2011-2022 走看看