在dao层经常使用查询语句找到数据库中表中记录,但实际操作时往往希望返回的是实体对象集合而不是值对象数组集合。
根据目前的学习,有以下几种方法:
1.hql语句返回结果为实体对象集合;所以能用 hql语句尽量用hql语句
2原生sql语句查询:List cats = this.getSession().createSQLQuery( " select * from cats " ).addEntity(Cat. class ).list(); 通过添加addEntity()来实现返回具体类
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();
原生的S