view安全服务器映射,Hibernate 映射view

在初学Hibernate的时候就听说此技术对View支持的不是很好。因为我也没有用到也就没有多想。后来因为工程需要,不得不对此作一番研究。最终找到了一条可行的解决方案。特此总结,共大家分享。

一、思路

问题:

以往用Hibernate处理View时发生的困难主要集中在这两方面:

View是没有主键

由于View是由select语句生成,所以不存在任何主键。也就无法对其映射。

Hibernate必须对要操作的表进行po封装

Hibernate要求对数据库的操作都是通过pojo映射来实现的。也就是说无法对某个View直接读取而不对其进行映射。

解决:

要解决以上问题,我采取一下方案:

在建立View的时候生成类似主键的字段

通过其他手段建立类似主键的字段。

在映射po的时候手动把这个字段改为主键

将虚拟字段改为主键。根据虚拟的情况给以不同的自增长类型。

二、实现

我是在Oracle+Tomcat环境下测试成功的。

下面详细介绍一下步骤。

建立视图

代码

createorreplaceviewv_user_perm

(id,userid,moduleid)

as

selectrownum,a.id,c.id

fromsysusera,user_permb,modulec

wherea.id=b.userid

andb.moduleid=c.id

这个视图是从两个表中分别取出id,然后我将生成的视图的行号作为id处理。

建立xml

代码

-//Hibernate/Hibernate Mapping DTD 2.0//EN""">

建立java

代码

importjava.io.Serializable;

importorg.apache.commons.lang.builder.ToStringBuilder;

/** @author Hibernate CodeGenerator */

publicclassVUserPermimplementsSerializable{

/** persistent field */

privatelongid;

/** persistent field */

privateStringuserid;

/** persistent field */

privateStringmoduleid;

/** full constructor */

publicVUserPerm(Stringuserid,Stringmoduleid){

this.userid=userid;

this.moduleid=moduleid;

}

/** default constructor */

publicVUserPerm(){

}

publiclonggetId(){

returnthis.id;

}

publicvoidsetId(longid){

this.id=id;

}

publicStringgetUserid(){

returnthis.userid;

}

publicvoidsetUserid(Stringuserid){

this.userid=userid;

}

publicStringgetModuleid(){

returnthis.moduleid;

}

publicvoidsetModuleid(Stringmoduleid){

this.moduleid=moduleid;

}

publicStringtoString(){

returnnewToStringBuilder(this)

.toString();

}

}

这样就一个把一个视图当成表来查询了。不过插入是不可能的了。

大家有什么看法可以一起讨论。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值