网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > JAVA > 高级技术 > 设计模式 > Hibernate一对多单向关系  

Hibernate一对多单向关系

2006-05-10  作者:网管整理  来源:bitsCN.com  点评 投稿 收藏

1.   数据库schema

Teachers: 网管u家u.bitsCN.com

create table TEACHERS 网管网www_bitscn_com

( 网管联盟bitsCN_com

  ID          NUMBER(10) not null, 中国网管论坛bbs.bitsCN.com

  TEACHERNAME VARCHAR2(15)

网管论坛bbs_bitsCN_com

) 网管论坛bbs_bitsCN_com

alter table TEACHERS 中国网管论坛bbs.bitsCN.com

  add constraint DERE primary key (ID)

网管论坛bbs_bitsCN_com

 

网管u家u.bitsCN.com

Students表:

网管论坛bbs_bitsCN_com

create table STUDENTS 网管联盟bitsCN@com

(

网管下载dl.bitscn.com

  ID          NUMBER(10) not null,

网管u家u.bitsCN.com

  STUDENTNAME VARCHAR2(15), 网管u家u.bitsCN.com

  TEACHER_ID  NUMBER(10) 网管bitscn_com

)

网管联盟bitsCN@com

alter table STUDENTS

网管u家u.bitsCN.com

  add constraint RERE primary key (ID) 网管u家u.bitsCN.com

alter table STUDENTS

中国网管论坛bbs.bitsCN.com

  add constraint FFF foreign key (TEACHER_ID) 网管下载dl.bitscn.com

  references TEACHERS (ID);

网管网www.bitscn.com

  网管论坛bbs_bitsCN_com

2.   Teacher.javaStudent.java

Teacher.java

网管联盟bitsCN_com

package mypack; 中国网管论坛bbs.bitsCN.com

  中国网管论坛bbs.bitsCN.com

public class Teacher {

网管u家u.bitscn@com

  //教师id 中国网管联盟bitsCN.com

  private Long id;

网管u家u.bitscn@com

  中国网管论坛bbs.bitsCN.com

  //教师名称

网管下载dl.bitscn.com

  private String teacherName; 网管联盟bitsCN_com

 

网管网www.bitscn.com

  /**

网管u家u.bitsCN.com

   * 缺省构造函数

网管u家u.bitscn@com

   */

网管联盟bitsCN@com

  public Teacher() { 网管网www_bitscn_com

  }

网管u家u.bitscn@com

 

网管网www_bitscn_com

  /**

网管论坛bbs_bitsCN_com

   * 得到教师id

网管bitscn_com

   * @return Long    教师id

网管网www.bitscn.com

   */ 网管论坛bbs_bitsCN_com

  public Long getId() {

网管u家u.bitscn@com

    return id;

网管下载dl.bitscn.com

  }

网管下载dl.bitscn.com

  网管下载dl.bitscn.com

  /**

中国网管论坛bbs.bitsCN.com

   * 设置教师id

中国网管论坛bbs.bitsCN.com

   * @param id Long    教师id

网管下载dl.bitscn.com

   */ 中国网管论坛bbs.bitsCN.com

  public void setId(Long id) { 网管u家u.bitscn@com

    this.id = id;

中国网管论坛bbs.bitsCN.com

  } 网管bitscn_com

  中国网管论坛bbs.bitsCN.com

  /** 网管联盟bitsCN_com

   * 得到教师名称

网管网www.bitscn.com

   * @return String    教师名称 网管u家u.bitsCN.com

   */ 中国网管论坛bbs.bitsCN.com

  public String getTeacherName() {

网管下载dl.bitscn.com

    return teacherName;

网管u家u.bitsCN.com

  } 网管bitscn_com

  

中国网管联盟bitsCN.com

  /** 网管网www_bitscn_com

   * 设置教师名称 网管u家u.bitsCN.com

   * @param teacherName String    教师名称 中国网管联盟bitsCN.com

   */ 网管bitscn_com

  public void setTeacherName(String teacherName) { 网管u家u.bitscn@com

    this.teacherName = teacherName; 网管论坛bbs_bitsCN_com

  } 中国网管联盟bitsCN.com

 

网管联盟bitsCN@com

  /** 网管bitscn_com

   * 构造函数

中国网管联盟bitsCN.com

   * @param teacherName String

网管u家u.bitscn@com

   */

网管联盟bitsCN_com

  public Teacher(String teacherName) {

网管网www.bitscn.com

    this.teacherName = teacherName; 网管论坛bbs_bitsCN_com

  }

网管联盟bitsCN_com

} 网管u家u.bitscn@com

  中国网管论坛bbs.bitsCN.com

Student.java 网管论坛bbs_bitsCN_com

package mypack; 网管网www_bitscn_com

 

网管联盟bitsCN@com

public class Student {

中国网管论坛bbs.bitsCN.com

  //学生id 网管联盟bitsCN_com

  private Long id; 网管联盟bitsCN_com

  网管下载dl.bitscn.com

  //学生名称

网管网www.bitscn.com

  private String studentName; 网管下载dl.bitscn.com

  网管下载dl.bitscn.com

  //教师类

网管bitscn_com

  private Teacher teacher;

网管bitscn_com

 

网管网www_bitscn_com

  /**

网管bitscn_com

   * 缺省构造函数

网管u家u.bitsCN.com

   */ 中国网管论坛bbs.bitsCN.com

  public Student() {

网管u家u.bitscn@com

  } 网管bitscn_com

 

网管bitscn_com

  /**

中国网管论坛bbs.bitsCN.com

   * 得到学生id 网管下载dl.bitscn.com

   * @return Long    学生id 网管联盟bitsCN_com

   */ 网管bitscn_com

  public Long getId() {

网管联盟bitsCN@com

    return id; 网管网www_bitscn_com

  }

网管网www_bitscn_com

  中国网管论坛bbs.bitsCN.com

  /**

网管u家u.bitsCN.com

   * 设置学生id 网管联盟bitsCN_com

   * @param id Long    学生id 中国网管联盟bitsCN.com

   */ 网管联盟bitsCN@com

  public void setId(Long id) {

网管下载dl.bitscn.com

    this.id = id;

中国网管联盟bitsCN.com

  } 网管u家u.bitsCN.com

  中国网管联盟bitsCN.com

  /** 网管bitscn_com

   * 得到学生名称

网管网www.bitscn.com

   * @return String    学生名称

网管联盟bitsCN_com

   */

网管bitscn_com

  public String getStudentName() { 网管论坛bbs_bitsCN_com

    return studentName;

网管u家u.bitscn@com

  } 中国网管论坛bbs.bitsCN.com

 

网管联盟bitsCN@com

  /** 中国网管联盟bitsCN.com

   * 设置学生名称

网管bitscn_com

   * @param studentName String    学生名称 网管下载dl.bitscn.com

   */ 网管网www_bitscn_com

  public void setStudentName(String studentName) { 网管论坛bbs_bitsCN_com

    this.studentName = studentName; 网管u家u.bitscn@com

  }

网管联盟bitsCN_com

 

网管论坛bbs_bitsCN_com

  /** 网管u家u.bitscn@com

   * 得到教师对象

网管u家u.bitscn@com

   * @return Teacher    教师对象

网管bitscn_com

   */ 网管联盟bitsCN@com

  public Teacher getTeacher() {

网管网www_bitscn_com

    return teacher;

网管u家u.bitsCN.com

  }

网管网www.bitscn.com

 

网管联盟bitsCN@com

  /** 网管联盟bitsCN_com

   * 设置教师对象 网管u家u.bitsCN.com

   * @param teacher Teacher    教师对象

网管u家u.bitsCN.com

   */ 网管联盟bitsCN@com

  public void setTeacher(Teacher teacher) {

中国网管联盟bitsCN.com

    this.teacher = teacher;

中国网管论坛bbs.bitsCN.com

  }

网管论坛bbs_bitsCN_com

  中国网管联盟bitsCN.com

  /** 网管u家u.bitscn@com

   * 构造函数 网管u家u.bitsCN.com

   * @param string String 网管网www.bitscn.com

   * @param teacher Teacher

中国网管联盟bitsCN.com

   */

网管论坛bbs_bitsCN_com

  public Student(String studentName, Teacher teacher) { 网管网www_bitscn_com

    this.studentName = studentName; 中国网管联盟bitsCN.com

    this.teacher = teacher; 网管网www_bitscn_com

  } 中国网管论坛bbs.bitsCN.com

}

网管u家u.bitsCN.com

  网管u家u.bitsCN.com

3.   hibernate.properties

## Oracle 网管网www_bitscn_com

  中国网管联盟bitsCN.com

hibernate.dialect net.sf.hibernate.dialect.Oracle9Dialect 网管u家u.bitscn@com

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

网管论坛bbs_bitsCN_com

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

网管bitscn_com

hibernate.connection.username jbcm

中国网管论坛bbs.bitsCN.com

hibernate.connection.password jbcm 网管下载dl.bitscn.com

hibernate.connection.url jdbc:oracle:thin:@localhost:1521:wsy 中国网管论坛bbs.bitsCN.com

  网管下载dl.bitscn.com

4.   Teacher.hbm.xmlStudent.hbm.xml

Teacher.hbm.xml

网管下载dl.bitscn.com

<?xml version="1.0"?>

网管bitscn_com

<!DOCTYPE hibernate-mapping 中国网管论坛bbs.bitsCN.com

PUBLIC "-//Hibernate/Hibernate Mapping DTD 2.0//EN" 网管联盟bitsCN_com

"http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"> 中国网管论坛bbs.bitsCN.com

<hibernate-mapping > 中国网管联盟bitsCN.com

  中国网管联盟bitsCN.com

  <class name="mypack.Teacher" table="teachers" > 网管网www_bitscn_com

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

网管u家u.bitscn@com

      <generator class="increment"/>

中国网管论坛bbs.bitsCN.com

    </id> 网管下载dl.bitscn.com

  网管u家u.bitscn@com

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

网管bitscn_com

        <column name="teacherName" length="15" /> 网管论坛bbs_bitsCN_com

    </property>

网管u家u.bitsCN.com

 

网管u家u.bitsCN.com

  </class> 中国网管论坛bbs.bitsCN.com

 

网管网www_bitscn_com

</hibernate-mapping>

网管论坛bbs_bitsCN_com

  中国网管联盟bitsCN.com

Student.hbm.xml 网管联盟bitsCN_com

<?xml version="1.0"?>

网管联盟bitsCN_com

<!DOCTYPE hibernate-mapping

网管下载dl.bitscn.com

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

网管bitscn_com

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

网管u家u.bitscn@com

<hibernate-mapping >

网管网www.bitscn.com

  网管下载dl.bitscn.com

  <class name="mypack.Student" table="students" > 网管网www.bitscn.com

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

网管u家u.bitsCN.com

      <generator class="increment"/> 中国网管联盟bitsCN.com

    </id> 网管下载dl.bitscn.com

  网管联盟bitsCN@com

    <property name="studentName" type="string" > 中国网管联盟bitsCN.com

        <column name="studentName" length="15" /> 网管u家u.bitsCN.com

    </property>

网管联盟bitsCN_com

 

网管bitscn_com

   <many-to-one 中国网管联盟bitsCN.com

        name="teacher"

网管bitscn_com

        column="teacher_id" 网管下载dl.bitscn.com

        class="mypack.Teacher"

网管联盟bitsCN_com

        cascade="save-update"

网管联盟bitsCN_com

       /> 网管网www_bitscn_com

 

中国网管联盟bitsCN.com

  </class>

网管联盟bitsCN@com

 

网管论坛bbs_bitsCN_com

</hibernate-mapping>

中国网管联盟bitsCN.com

网管u家u.bitscn@com

5.   数据库操作类
BusinessService.java
package mypack;
 
import net.sf.hibernate.*;
import net.sf.hibernate.cfg.Configuration;
import java.util.*;
 
public class BusinessService{
 //session工厂类
 public static SessionFactory sessionFactory;
 
 //实始化session工厂
 static{
     try{
       //建立配置类,添加Student类和Teacher类
       Configuration config = new Configuration();
       config.addClass(Student.class)
             .addClass(Teacher.class);
      //得到sessionFactory对象
      sessionFactory = config.buildSessionFactory();
    }catch(Exception e){e.printStackTrace();}
 }
 
 /**
   * 通过学生类,查找教师类
   * @param student Student
   * @throws Exception
   * @return List
   */
 public List findTeacherByStudent(Student student) throws Exception{
    Session session = sessionFactory.openSession();
    Transaction tx = null;
    try {
      tx = session.beginTransaction();
 
      List orders=(List)session.find("from Student as o where o.teacher.id="+student.getId());
      tx.commit();
      return orders;
    }catch (Exception e) {
      if (tx != null) {
        tx.rollback();
      }
      throw e;
    } finally {
      session.close();
    }
 }
 
 /**
   * 查找指定id的学生类
   * @param student_id long
   * @throws Exception
   * @return Student
   */
 public Student findStudent(long student_id) throws Exception{
    Session session = sessionFactory.openSession();
    Transaction tx = null;
    try {
      tx = session.beginTransaction();
      Student student=(Student)session.load(Student.class,new Long(student_id));
      tx.commit();
      return student;
    }catch (Exception e) {
      if (tx != null) {
        //发生错误,回滚
        tx.rollback();
      }
      throw e;
    } finally {
      //没有错误,关闭session
      session.close();
    }
 }
 
 /**
   * 级连保存Teacher对象和Student对象
   * @throws Exception
   */
 public void saveTeacherAndStudentWithCascade() throws Exception{
    Session session = sessionFactory.openSession();
    Transaction tx = null;
    try {
      tx = session.beginTransaction();
 
      Teacher teacher=new Teacher("myTeacher");
      Student student1=new Student("student1",teacher);
      Student student2=new Student("student2",teacher);
 
      session.save(student1);
      session.save(student2);
 
      tx.commit();
 
    }catch (Exception e) {
      if (tx != null) {
        //发生错误,回滚
        tx.rollback();
      }
      e.printStackTrace();
    } finally {
      // 没有错误,关闭session
      session.close();
    }
 }
 
 /**
   * 保存教师和学生对象
   * @throws Exception
   */
 public void saveTeacherAndStudent() throws Exception{
    Session session = sessionFactory.openSession();
    Transaction tx = null;
    try {
      tx = session.beginTransaction();
 
      Teacher teacher=new Teacher("teacher1");
      session.save(teacher);
 
      Student student1=new Student("student001",teacher);
      Student student2=new Student("student002",teacher);
      session.save(student1);
      session.save(student2);
      //提交事务
      tx.commit();
 
    }catch (Exception e) {
      if (tx != null) {
        //发生错误,回滚
        tx.rollback();
      }
      throw e;
    } finally {
      // 没有错误,关闭session
      session.close();
    }
 }
 
 /**
   * 输出学生对象集合
   * @param students List
   */
 public void printStudents(List students){
      for (Iterator it = students.iterator(); it.hasNext();) {
         Student student=(Student)it.next();
         System.out.println("OrderNumber of "+student.getTeacher().getTeacherName()+ " :"+student.getStudentName());
      }
 }
 
 /**
   * 测试方法
   * @throws Exception
   */
 public void test() throws Exception{
      saveTeacherAndStudent();
//      saveTeacherAndStudentWithCascade();
//      Student student=findStudent(1);
//      List students=findTeacherByStudent(student);
//      printStudents(students);
 }
 
 public static void main(String args[]) throws Exception {
    new BusinessService().test();
    sessionFactory.close();
 }
}
 
 
目录结构示意:
Classes
                  Hibernate.property
       /mypack
                  Teacher.java
                             Student.java
                  BusinessService.java
                  Teacher.hbm.xml
                             Student.hbm.xml      

 

中国网管论坛bbs.bitsCN.com


TAGs   关系   单向   id   public   Student   教师   teacher   Teacher      
 上一篇:谨慎使用类变量及正确使用单例模式   下一篇:用Java Annotations管理对象生命周期
Hibernate一对多单向关系 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
最新推荐文章:
网管论坛交流: