首页 | 互联网 | IT动态 | Cisco | Windows | Linux | Java | .Net | Oracle | 华为 | 存储世界 | 服务器 | 网络设备 | IDC | 安全 | 求职招聘
IT培训 | 数字网校 | 技术专题 | 电子书下载 | 教学视频 | 网页设计 | 平面设计 | 解决方案 | 直播室 | 虚拟考场 | 搜索 | 博客 | 沙龙 | 论坛
中国IT实验室Linux频道
中国IT教育
 
首页 资讯动态 认证考试 新手入门 核心技术 高级技术 J2EE J2ME Java&XML 开源技术 其他技术 RSS订阅 论坛 专题
您现在的位置: 中国IT实验室 >> Java >> 高级技术 >> 设计模式 >> 文章正文

Hibernate一对多单向关系

文章来源Chinaitlab收集整理 作者佚名 更新时间2006-5-10 保存本文保存本文 推荐给好友推荐给好友 收藏本页收藏本页

1.   数据库schema

Teachers:

create table TEACHERS

(

  ID          NUMBER(10) not null,

  TEACHERNAME VARCHAR2(15)

)

alter table TEACHERS

  add constraint DERE primary key (ID)

 

Students表:

create table STUDENTS

(

  ID          NUMBER(10) not null,

  STUDENTNAME VARCHAR2(15),

  TEACHER_ID  NUMBER(10)

)

alter table STUDENTS

  add constraint RERE primary key (ID)

alter table STUDENTS

  add constraint FFF foreign key (TEACHER_ID)

  references TEACHERS (ID);

 

2.   Teacher.javaStudent.java

Teacher.java

package mypack;

 

public class Teacher {

  //教师id

  private Long id;

 

  //教师名称

  private String teacherName;

 

  /**

   * 缺省构造函数

   */

  public Teacher() {

  }

 

  /**

   * 得到教师id

   * @return Long    教师id

   */

  public Long getId() {

    return id;

  }

 

  /**

   * 设置教师id

   * @param id Long    教师id

   */

  public void setId(Long id) {

    this.id = id;

  }

 

  /**

   * 得到教师名称

   * @return String    教师名称

   */

  public String getTeacherName() {

    return teacherName;

  }

  

  /**

   * 设置教师名称

   * @param teacherName String    教师名称

   */

  public void setTeacherName(String teacherName) {

    this.teacherName = teacherName;

  }

 

  /**

   * 构造函数

   * @param teacherName String

   */

  public Teacher(String teacherName) {

    this.teacherName = teacherName;

  }

}

 

Student.java

package mypack;

 

public class Student {

  //学生id

  private Long id;

 

  //学生名称

  private String studentName;

 

  //教师类

  private Teacher teacher;

 

  /**

   * 缺省构造函数

   */

  public Student() {

  }

 

  /**

   * 得到学生id

   * @return Long    学生id

   */

  public Long getId() {

    return id;

  }

 

  /**

   * 设置学生id

   * @param id Long    学生id

   */

  public void setId(Long id) {

    this.id = id;

  }

 

  /**

   * 得到学生名称

   * @return String    学生名称

   */

  public String getStudentName() {

    return studentName;

  }

 

  /**

   * 设置学生名称

   * @param studentName String    学生名称

   */

  public void setStudentName(String studentName) {

    this.studentName = studentName;

  }

 

  /**

   * 得到教师对象

   * @return Teacher    教师对象

   */

  public Teacher getTeacher() {

    return teacher;

  }

 

  /**

   * 设置教师对象

   * @param teacher Teacher    教师对象

   */

  public void setTeacher(Teacher teacher) {

    this.teacher = teacher;

  }

 

  /**

   * 构造函数

   * @param string String

   * @param teacher Teacher

   */

  public Student(String studentName, Teacher teacher) {

    this.studentName = studentName;

    this.teacher = teacher;

  }

}

 

3.   hibernate.properties

## Oracle

 

hibernate.dialect net.sf.hibernate.dialect.Oracle9Dialect

hibernate.dialect net.sf.hibernate.dialect.OracleDialect

hibernate.connection.driver_class oracle.jdbc.driver.OracleDriver

hibernate.connection.username jbcm

hibernate.connection.password jbcm

hibernate.connection.url jdbc:oracle:thin:@localhost:1521:wsy

 

4.   Teacher.hbm.xmlStudent.hbm.xml

Teacher.hbm.xml

<?xml version="1.0"?>

<!DOCTYPE hibernate-mapping

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

"http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">

<hibernate-mapping >

 

  <class name="mypack.Teacher" table="teachers" >

    <id name="id" type="long" column="ID">

      <generator class="increment"/>

    </id>

 

    <property name="teacherName" type="string" >

        <column name="teacherName" length="15" />

    </property>

 

  </class>

 

</hibernate-mapping>

 

Student.hbm.xml

<?xml version="1.0"?>

<!DOCTYPE hibernate-mapping

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

"http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">

<hibernate-mapping >

 

  <class name="mypack.Student" table="students" >

    <id name="id" type="long" column="ID">

      <generator class="increment"/>

    </id>

 

    <property name="studentName" type="string" >

        <column name="studentName" length="15" />

    </property>

 

   <many-to-one

        name="teacher"

        column="teacher_id"

        class="mypack.Teacher"

        cascade="save-update"

       />

 

  </class>

 

</hibernate-mapping>

[1] [2] 下一页  

【责编:wayen】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 社区讨论
 博客论点