hibernate执行sql语句的总结_sql语句初学使用总结

2020-02-28 其他工作总结 下载本文

hibernate执行sql语句的总结由刀豆文库小编整理,希望给你工作、学习、生活带来方便,猜你可能喜欢“sql语句初学使用总结”。

下面看个示例: public List 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

nu“,Menu.cla).list();

return menus;

}

1.通过addEntity(”menu“,Menu.cla),通过addEntity把要返回的数据强转为Menu,注意Menu必须要是配置hibernate映射了的。m.id as {menu.id},这是为了如果数据库字段名和Menu模型中不一样所以都as取了个别名,那么这样就能返回menu对象了。

2、如果要执行的sql语句是多表查询,并且是返回一个对象。但是这个对象是没有配置hibernate映射的。这种就麻烦了。hibernate执行SQL默认返回的是一个object类型的数组,List menus

=super.getSeionFactory().getCurrentSeion().createSQLQuery(hql).list();

for(int i=0;i

{Object[] objects =(Object[])menus.get(i);for(int j=0;j

运行后报错:java.lang.ClaCastExceptionjava.lang.Object;cannot be cast to

net.greatsoft.ch.domain.privilege.model.Menu,原来是查询出来的字段并不能自动转换为bean对象,所以要添加addEntity(Clazz cla)。有人肯定会说添加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返回,就不是很menus = super.getSeionFactory().getCurrentSeion().createSQLQuery(hql).addEntity(”me

方便

突然发现createSQLQuery有这样一个方法可以直接转换对象

Query query = seion.createSQLQuery(sql).addEntity(XXXXXXX.cla);

XXXXXXX 代表以hibernate生成的Bean的对象,也就是数据表映射出的Bean。但是这个bean必须有映射

呵呵以后多注意,还是时不时的要看看hibernate各个对象方法的使用.

《hibernate执行sql语句的总结.docx》
将本文的Word文档下载,方便收藏和打印
推荐度:
hibernate执行sql语句的总结
点击下载文档
相关专题 sql语句初学使用总结 语句 Hibernate sql sql语句初学使用总结 语句 Hibernate sql
[其他工作总结]相关推荐
    [其他工作总结]热门文章
      下载全文