zoukankan      html  css  js  c++  java
  • hibernate 联合主键

    xml配置

    需要一个主键类:

    package com.bxw.entity;
    
    import java.io.Serializable;
    
    
    public class StudentPk implements Serializable{
        private String id;
        private String name;
        public String getId() {
            return id;
        }
        public void setId(String id) {
            this.id = id;
        }
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
        
        @Override
        public boolean equals(Object obj) {
            if(obj instanceof StudentPk){
                StudentPk pk = (StudentPk)obj;
                if(this.name.equals(pk.getName()) && this.id.equals(pk.getId())){
                    return true;
                }
                return false;
            }
            return false;
        }
        
        @Override
        public int hashCode() {
            return this.id.hashCode();
        }
    }

    该主键类必须implements序列化的Serializable接口;

    该主键类必须重写equals()、hashCode()方法。

    实体:

    package com.bxw.entity;
    
    public class Student {
        private StudentPk pk;
        private String sex;
        
        public StudentPk getPk() {
            return pk;
        }
        public void setPk(StudentPk pk) {
            this.pk = pk;
        }
        public String getSex() {
            return sex;
        }
        public void setSex(String sex) {
            this.sex = sex;
        }
        
        
    }

    配置文件

    <?xml version="1.0" encoding='UTF-8'?>  
      
    <!DOCTYPE hibernate-mapping PUBLIC   
         "-//Hibernate/Hibernate Mapping DTD 3.0//EN"   
         "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
    <hibernate-mapping package="com.bxw.entity">  
       <class name="Student">  
          <composite-id name="pk" class="com.bxw.entity.StudentPk">
              <key-property name="id"></key-property>
            <key-property name="name"></key-property>
          </composite-id>        
          <property name="sex"></property>  
       </class>
    </hibernate-mapping>  
  • 相关阅读:
    JQuery缓冲加载图片插件lazyload.js的使用方法
    CSS3阴影 box-shadow的使用和技巧总结
    HTML符号大全
    TouchSlide
    响应式图片的3种解决方案
    ECMAScript arguments 对象
    call() 方法 和 apply()方法详解
    字体图标 iconfont cssfont
    响应式样式
    1-微信小程序创建项目
  • 原文地址:https://www.cnblogs.com/popcornya/p/7248069.html
Copyright © 2011-2022 走看看