`
pengchua
  • 浏览: 152687 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

Hibernate中引用View的解决方案_来自一网友,在此表示谢谢

阅读更多

一、思路
问题:
以往用Hibernate处理View时发生的困难主要集中在这两方面:
View是没有主键
由于View是由select语句生成,所以不存在任何主键。也就无法对其映射。
Hibernate必须对要操作的表进行po封装
Hibernate要求对数据库的操作都是通过pojo映射来实现的。也就是说无法对某个View直接读取而不对其进行映射。
解决:
要解决以上问题,我采取一下方案:
在建立View的时候生成类似主键的字段
通过其他手段建立类似主键的字段。
在映射po的时候手动把这个字段改为主键
将虚拟字段改为主键。根据虚拟的情况给以不同的自增长类型。
二、实现
建立视图

代码
  1. create or replace view v_user_perm   
  2. (id, userid, moduleid)   
  3. as   
  4. select rownum,a.id,c.id   
  5. from sysuser a,user_perm b,module c   
  6. where a.id=b.userid    
  7. and b.moduleid=c.id  
<script type="text/javascript">render_code();</script>
这个视图是从两个表中分别取出id,然后我将生成的视图的行号作为id处理。
建立xml
代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 2.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">  
  3. <hibernate-mapping>  
  4. <class name="com.fulong.journal.cad.po.perm.VUserPerm" table="V_USER_PERM" schema="JCAD">  
  5. <id name="id" column="ID" type="long">  
  6. <generator class="increment"/>  
  7. </id>  
  8. <property name="userid" column="USERID" type="string" length="32" not-null="true"/>  
  9. <property name="moduleid" column="MODULEID" type="string" length="32" not-null="true"/>  
  10. </class>  
  11. </hibernate-mapping>  
<script type="text/javascript">render_code();</script>
建立java
代码
  1.   
  2. import java.io.Serializable;   
  3. import org.apache.commons.lang.builder.ToStringBuilder;   
  4.   
  5. /** @author Hibernate CodeGenerator */  
  6. public class VUserPerm implements Serializable {   
  7.   
  8.     /** persistent field */  
  9.     private long id;   
  10.   
  11.     /** persistent field */  
  12.     private String userid;   
  13.   
  14.     /** persistent field */  
  15.     private String moduleid;   
  16.   
  17.     /** full constructor */  
  18.     public VUserPerm(String userid, String moduleid) {   
  19.         this.userid = userid;   
  20.         this.moduleid = moduleid;   
  21.     }   
  22.   
  23.     /** default constructor */  
  24.     public VUserPerm() {   
  25.     }   
  26.     public long getId() {   
  27.         return this.id;   
  28.     }   
  29.   
  30.     public void setId(long id) {   
  31.         this.id = id;   
  32.     }   
  33.   
  34.     public String getUserid() {   
  35.         return this.userid;   
  36.     }   
  37.   
  38.     public void setUserid(String userid) {   
  39.         this.userid = userid;   
  40.     }   
  41.   
  42.     public String getModuleid() {   
  43.         return this.moduleid;   
  44.     }   
  45.   
  46.     public void setModuleid(String moduleid) {   
  47.         this.moduleid = moduleid;   
  48.     }   
  49.   
  50.     public String toString() {   
  51.         return new ToStringBuilder(this)   
  52.             .toString();   
  53.     }   
  54.   
  55. }  
 注意:
view一般用在小涉及到多个表的组合查询时用到,用来提高效率!
view不能插入数据。


分享到:
评论

相关推荐

    struts2_spring_hibernate jar图

    Struts2、Spring和Hibernate是Java Web开发中的三个核心框架,它们共同构建了一个强大的MVC(Model-View-Controller)架构。Struts2提供了动作控制和业务逻辑处理,Spring提供了依赖注入和事务管理,而Hibernate则...

    struts_hibernate_velocity_mysql 实现用户登录和注册

    Struts、Hibernate、Velocity 和 MySQL 是四个在Java Web开发中常用的开源技术,它们结合使用可以构建出高效、灵活且功能强大的...同时,理解这一组合的工作原理,也能帮助你在遇到类似问题时,更快地找到解决方案。

    Struts整合hibernate的学生管理系统

    在"Struts整合hibernate的学生管理系统"中,这两者被结合起来,为学生信息的管理提供了高效且灵活的解决方案。 **1. Struts框架** Struts框架的核心是ActionServlet,它接收HTTP请求,根据配置的ActionMapping决定...

    一个struts2+hibernate+spring整合的例子

    Spring框架在此中的作用主要体现在两方面:一是管理Bean,通过XML或注解方式定义Bean及其依赖关系,实现Bean的自动装配;二是提供事务管理,确保数据操作的一致性。在与Hibernate集成时,Spring可以管理Hibernate的...

    struts sping hibernate

    Struts、Spring 和 Hibernate 是Java开发中非常著名的三个开源框架,它们共同构成了SSH(Struts、Spring、Hibernate)集成解决方案,被广泛应用于企业级Web应用的开发中。这些框架分别负责不同的职责,协同工作以...

    Open_Session_In_View详解.doc

    为了解决这一问题,Spring框架提供了`Open Session In View`机制,这是一种简便而有效的解决方案。它能够在Web请求的整个生命周期内保持`Hibernate session`处于打开状态,从而支持懒加载数据的获取,无需在应用层...

    struts2hibernate例子.zip

    Spring集成了Struts2和Hibernate,提供了一个更全面的解决方案,包括依赖注入、AOP(面向切面编程)等,使得企业级应用的开发更加高效和灵活。所以,深入理解Struts2和Hibernate的整合,对于成为Java Web开发的专家...

    bank(struts+hibernate)

    "Bank (Struts+Hibernate)" 是一个典型的Java Web应用程序,它展示了如何将两个流行的开源框架——Struts和Hibernate——结合在一起,以实现一个功能完善的网上银行系统。这个项目旨在模拟银行的基本操作,如存款和...

    struts2.1.8+spring+hibernate框架整合所需jar包

    Spring框架是一个全面的后端解决方案,包括IOC(Inversion of Control,控制反转)和AOP(Aspect-Oriented Programming,面向切面编程)两大核心特性。IOC帮助管理对象的生命周期和依赖关系,而AOP则允许开发者定义...

    Struts2.1+Spring2.5+Hibernate3的jar包

    综上所述,Struts2.1、Spring2.5和Hibernate3的整合为Java Web开发提供了强大而灵活的解决方案。通过理解这三个框架各自的功能和它们之间的协作,开发者可以更高效地构建和维护企业级应用。同时,正确管理jar包是...

    利用MyEclipse开发Struts+Hibernate应用

    在IT行业中,构建基于Web的应用程序是常见的任务,而Struts和Hibernate是两个非常重要的开源框架,它们分别处理MVC(Model-View-Controller)架构的控制层和数据持久化层。MyEclipse是一款强大的集成开发环境(IDE)...

    JSP源码——车辆管理系统(struts+hibernate+spring+oracle).zip

    Oracle数据库是这个系统的数据存储中心,它提供了高性能、高可靠性的数据存储解决方案。在车辆管理系统中,Oracle数据库可能包含了如车辆信息表、用户信息表、租赁记录表等多个数据表,用于存储和检索系统所需的各种...

    struts spring hibernate ssh 三大框架集成详细步骤 手把手教你搭框架

    SSH(Struts + Spring + Hibernate)框架集成旨在实现MVC(Model-View-Controller)设计模式,为业务逻辑、数据访问以及用户交互提供了高效的解决方案。 **Struts框架**: Struts是一个开源的MVC框架,负责处理用户...

    jsf1.2 hibernate整合小例子

    总之,JSF 1.2 和 Hibernate 的整合提供了一个高效、灵活的解决方案,使得开发人员能够快速构建功能丰富的 Web 应用,同时保持代码的清晰性和可维护性。通过实践这个小例子,你可以深入了解如何在实际项目中运用这两...

    常用jar包struts2、spring、hibernate、jquery、json

    Hibernate支持实体类、持久化映射、HQL(Hibernate Query Language)以及 Criteria 查询,提供了一套完整的数据访问解决方案。 jQuery是一个广泛使用的JavaScript库,它极大地简化了DOM操作、事件处理、动画效果和...

    ssh2(struts2+spring2.5+hibernate3.3+ajax)带进度条文件上传(封装成标签)

    Spring框架是一个全面的后端开发解决方案,包括依赖注入、面向切面编程、事务管理等。Spring2.5版本引入了对JSR-303 Bean Validation的支持以及改进的AOP和Web MVC功能。在这个项目中,Spring主要负责服务层的管理...

    SSH2_自动生成数据库框架整合-泛型引用(自写)

    Spring框架作为一个全面的后端解决方案,它不仅包含依赖注入(DI)和面向切面编程(AOP)等功能,还提供了对其他框架如Struts2和Hibernate的集成支持。在这个项目中,Spring可能被用来管理Struts2和Hibernate的生命...

    Struts2.0+Hibernate+Spring电子拍卖系统

    "Struts2.0+Hibernate+Spring电子拍卖系统"是一个基于Java技术的电子商务平台,集成了三个关键的开源框架:Struts2、Hibernate和Spring,它们共同构建了一个功能强大、可扩展性强的Web应用程序。这个系统允许全球...

    strutsspringhibernate整合

    Struts、Spring 和 Hibernate 是Java...在实际开发中,SSH整合能提高开发效率,降低模块间的耦合度,同时提供了一套完整的解决方案,便于大型项目的管理和维护。理解并掌握SSH的整合,对于Java Web开发者来说至关重要。

    struts-hibernate-spring最全jar包.rar

    Struts、Hibernate和Spring是Java开发中非常重要的三个框架,它们分别在Web层、持久化层和业务层提供了解决方案。这个压缩包"struts-hibernate-spring最全jar包.rar"包含了这三个框架的核心库文件,使得开发者可以...

Global site tag (gtag.js) - Google Analytics