JPA学习笔记-EJB-04JPA关联映射总结--2

UxSysMenu

package module.system.vo;

  

/**

 * liuyan

 */

@Entity

@Table(name = "ux_sys_menu")

public class UxSysMenu implements java.io.Serializable {

 

    // Fields

 

    private Integer imenuid;

    private String smenuname;

    private String smenuurl;

    private Integer iparentid;

    private Integer iorder;

    private String simgico;

    private String isvisible;

    private Integer ilevel;

 

    /** default constructor */

    public UxSysMenu() {

    }

 

   

    //去掉双向关联映射,为了更新菜单时不影响角色实体记录  

    private Set<UxRole> uxRoles;

   

    @JSON(serialize = false)

    @ManyToMany(fetch = FetchType.LAZY)

    @JoinTable(name = "ux_sys_role_menu", joinColumns = { @JoinColumn(name = "menuId") }, inverseJoinColumns = { @JoinColumn(name = "roleId") })

    public Set<UxRole> getUxRoles() {

       return uxRoles;

    }

 

    public void setUxRoles(Set<UxRole> uxRoles) {

       this.uxRoles = uxRoles;

    }

 

    // Property accessors

    @Id

    @Column(name = "imenuid", unique = true, nullable = false)

    public Integer getImenuid() {

       return this.imenuid;

    }

 

    public void setImenuid(Integer imenuid) {

       this.imenuid = imenuid;

    }

 

    @Column(name = "smenuname", nullable = false, length = 512)

    public String getSmenuname() {

       return this.smenuname;

    }

 

    public void setSmenuname(String smenuname) {

       this.smenuname = smenuname;

    }

 

    @Column(name = "smenuurl", length = 128)

    public String getSmenuurl() {

       return this.smenuurl;

    }

 

    public void setSmenuurl(String smenuurl) {

       this.smenuurl = smenuurl;

    }

 

    @Column(name = "iparentid", nullable = false)

    public Integer getIparentid() {

       return this.iparentid;

    }

 

    public void setIparentid(Integer iparentid) {

       this.iparentid = iparentid;

    }

 

    @Column(name = "iorder")

    public Integer getIorder() {

       return this.iorder;

    }

 

    public void setIorder(Integer iorder) {

       this.iorder = iorder;

    }

 

    @Column(name = "simgico", length = 64)

    public String getSimgico() {

       return this.simgico;

    }

 

    public void setSimgico(String simgico) {

       this.simgico = simgico;

    }

 

    @Column(name = "isvisible", nullable = false, length = 8)

    public String getIsvisible() {

       return this.isvisible;

    }

 

    public void setIsvisible(String isvisible) {

       this.isvisible = isvisible;

    }

 

    @Column(name = "ilevel", nullable = true)

    public Integer getIlevel() {

       return this.ilevel;

    }

 

    public void setIlevel(Integer ilevel) {

       this.ilevel = ilevel;

    }

   

    /**

     * 是否主键相等

     */

    @Override

    public boolean equals(Object obj) {

      

       if(obj instanceof UxSysMenu){

           UxSysMenu uxSysMenu = (UxSysMenu)obj;

           if(uxSysMenu.imenuid == this.imenuid){

              return true;

           }

          

       }

      

       return false;

    }

 

    @Override

    public int hashCode() {

       // TODO Auto-generated method stub

       return this.imenuid;

    }

}

说明:菜单实体与用户实体差不多,我们只说说不同的地方。菜单实体实现了超级父类Objectequals(Object obj)hashCode()方法,这样在别的管理实体的Set<UxSysMenu>就可以区分集合中的元素哪些实体是重复的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
hibernate-jpa-2.1-api 1.0.2是一个Java持久化规范的实现库。它是基于JPA(Java Persistence API)2.1规范的Hibernate实现。Hibernate是一个流行的ORM(对象关系映射)框架,用于在Java应用程序和关系数据库之间进行数据持久化。 该版本的hibernate-jpa-2.1-api是对JPA 2.1规范的实现,并且是Hibernate团队为了确保应用程序与Java EE 7兼容性而发布的一个版本。 JPA是一种使用对象模型操作数据库的标准规范,它提供了一组API,使开发人员可以使用面向对象的方式访问和操作数据库。Hibernate作为一个JPA的实现,提供了许多附加的功能和特性,使得开发人员可以更加简化和灵活地进行数据库操作。 通过使用hibernate-jpa-2.1-api,开发人员可以使用JPA的标准API,以及Hibernate提供的独有特性,来实现应用程序的数据持久化需求。它提供了实体管理器,用于管理实体对象的生命周期,以及CRUD操作。此外,它还提供了用于查询和各种持久化注解的支持。 通常情况下,使用hibernate-jpa-2.1-api需要将其添加到项目的依赖中,并与其他必需的Hibernate库一起使用。开发人员需要熟悉JPA的基本概念和API,并且理解Hibernate特有的扩展和配置选项。 总的来说,hibernate-jpa-2.1-api 1.0.2提供了开发人员在使用JPA进行数据持久化时的基本工具和功能。它是Hibernate团队为了支持JPA 2.1规范而发布的一个版本,开发人员可以使用它来简化和灵活地操作数据库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值