hibernate执行sql语句的总结
2011-07-08 22:27
585 查看
最近这几天一直在玩hibernate,而且经常要在hibernate中执行SQL语句,所以在这记录一下,以防备用1、如果要执行的sql语句是多表查询,并且是返回一个对象。这个对象是配置hibernate映射的。这种是最简单的了
下面看个示例:
通过addEntity("menu",Menu.class),通过addEntity把要返回的数据强转为Menu,注意Menu必须要是配置hibernate映射了的。m.id as {menu.id},这是为了如果数据库字段名和Menu模型中不一样所以都as取了个别名,那么这样就能返回menu对象了。2、如果要执行的sql语句是多表查询,并且是返回一个对象。但是这个对象是没有配置hibernate映射的。这种就麻烦了。hibernate执行SQL默认返回的是一个object类型的数组,List menus =super.getSessionFactory().getCurrentSession().createSQLQuery(hql).list();for(int i=0;i<menus .size();i++){Object[] objects = (Object[])menus .get(i);for(int j=0;j<objects.length;j++){System.out.println(objects[j].getClass().getName());}运行后报错:java.lang.ClassCastExceptionjava.lang.Object; cannot be cast to net.greatsoft.chss.domain.privilege.model.Menu,原来是查询出来的字段并不能自动转换为bean对象,所以要添加addEntity(Clazz class)。有人肯定会说添加addEntity了,但是如果Menu没有添加hibernate映射的话,此时会报Menu unmapping。。。。。。就是没添加映射,
所以只能添加setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); //返回一个map,KEY:为DB中名称一致(大小写一致)遍历list时就可以。所以只能将返回的值变成Map,这样就好操作了,然后就可用反射取值了,详细看:hibernate 执行sql语句返回自定义对象
3、hibernate 中createQuery与createSQLQuery两者区别是:
前者用的hql语句进行查询,后者可以用sql语句查询
前者以hibernate生成的Bean为对象装入list返回,后者则是以对象数组进行存储
所以使用createSQLQuery有时候也想以hibernate生成的Bean为对象装入list返回,就不是很方便
突然发现createSQLQuery有这样一个方法可以直接转换对象
Query query = session.createSQLQuery(sql).addEntity(XXXXXXX.class);
XXXXXXX 代表以hibernate生成的Bean的对象,也就是数据表映射出的Bean。但是这个bean必须有映射
呵呵以后多注意,还是时不时的要看看hibernate各个对象方法的使用。
好了,就写到这,以后用到时,在补充
转自:http://www.ityangba.com/thread-333-1-1.html
下面看个示例:
public List<Menu> findMenusByEntityTypeId(Long id) { String hql = "select m.id as {menu.id},m.name as {menu.name},m.url as {menu.url},m.icon_url as {menu.iconUrl},m.parent_id as {menu.parentId}," +"m.serial_number as {menu.serialNo},m.admin as {menu.adminUse},m.system_admin as {menu.systemAdmin} ,m.program_name as {menu.programName}" +" from menu m, entity_type et, entity_admin_menu eam" +" where et.id = "+id+"" +" and m.program_name = '"+GlobalNames.PROGRAM_NAME_CHSS+"'" +" and et.id = eam.entity_id" +" and m.id = eam.menu_id"; List<Menu> menus = super.getSessionFactory().getCurrentSession().createSQLQuery(hql).addEntity("menu",Menu.class).list(); return menus; }
通过addEntity("menu",Menu.class),通过addEntity把要返回的数据强转为Menu,注意Menu必须要是配置hibernate映射了的。m.id as {menu.id},这是为了如果数据库字段名和Menu模型中不一样所以都as取了个别名,那么这样就能返回menu对象了。2、如果要执行的sql语句是多表查询,并且是返回一个对象。但是这个对象是没有配置hibernate映射的。这种就麻烦了。hibernate执行SQL默认返回的是一个object类型的数组,List menus =super.getSessionFactory().getCurrentSession().createSQLQuery(hql).list();for(int i=0;i<menus .size();i++){Object[] objects = (Object[])menus .get(i);for(int j=0;j<objects.length;j++){System.out.println(objects[j].getClass().getName());}运行后报错:java.lang.ClassCastExceptionjava.lang.Object; cannot be cast to net.greatsoft.chss.domain.privilege.model.Menu,原来是查询出来的字段并不能自动转换为bean对象,所以要添加addEntity(Clazz class)。有人肯定会说添加addEntity了,但是如果Menu没有添加hibernate映射的话,此时会报Menu unmapping。。。。。。就是没添加映射,
所以只能添加setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); //返回一个map,KEY:为DB中名称一致(大小写一致)遍历list时就可以。所以只能将返回的值变成Map,这样就好操作了,然后就可用反射取值了,详细看:hibernate 执行sql语句返回自定义对象
3、hibernate 中createQuery与createSQLQuery两者区别是:
前者用的hql语句进行查询,后者可以用sql语句查询
前者以hibernate生成的Bean为对象装入list返回,后者则是以对象数组进行存储
所以使用createSQLQuery有时候也想以hibernate生成的Bean为对象装入list返回,就不是很方便
突然发现createSQLQuery有这样一个方法可以直接转换对象
Query query = session.createSQLQuery(sql).addEntity(XXXXXXX.class);
XXXXXXX 代表以hibernate生成的Bean的对象,也就是数据表映射出的Bean。但是这个bean必须有映射
呵呵以后多注意,还是时不时的要看看hibernate各个对象方法的使用。
好了,就写到这,以后用到时,在补充
转自:http://www.ityangba.com/thread-333-1-1.html
相关文章推荐
- hibernate执行sql语句的总结
- hibernate执行sql语句的总结
- hibernate执行sql语句的总结
- hibernate执行sql语句的总结
- 使用hibernate执行sql语句
- 通过分析SQL语句的执行计划优化SQL(总结)
- 关于hibernate执行sql语句后,进程不关闭的问题
- Hibernate 执行原始SQL语句
- sqlalchemy使用总结(一)-执行原始sql语句
- Hibernate 执行sql语句返回yntax error: syntax error, expect LPAREN, actual NOT not
- hibernate执行的SQL语句返回的list集合用Object[]接收遍历
- hibernate执行sql语句步骤
- weblogic hibernate关于No Dialect mapping for JDBC type :-9 hibernate执行原生sql语句问题(www.50xiao.com)
- Hibernate执行原生态sql语句
- Hibernate直接执行sql语句,查询记录的个数
- hibernate执行sql语句
- 使用Hibernate的session执行任意SQL语句以及整个事务
- Hibernate执行sql语句
- 关于No Dialect mapping for JDBC type :-9 hibernate执行原生sql语句问题 .
- hibernate执行sql语句映射到实体类