溫馨提示:您的每一次轉載,體現了我寫此文的意義!!!煩請您在轉載時注明出處http://www.aygfsteel.com/sxyx2008/謝謝合作!!!

          雪山飛鵠

          溫馨提示:您的每一次轉載,體現了我寫此文的意義!!!煩請您在轉載時注明出處http://www.aygfsteel.com/sxyx2008/謝謝合作!!!

          BlogJava 首頁 新隨筆 聯系 聚合 管理
            215 Posts :: 1 Stories :: 674 Comments :: 0 Trackbacks

          SQL
          create table Department
          (
             id                   
          int not null auto_increment,
             name                 
          varchar(20),
             
          primary key (id)
          );

          create table Employee
          (
             id                   
          int not null auto_increment,
             name                 
          varchar(20),
             deptid               
          int,
             
          primary key (id)
          );

          alter table Employee add constraint FK_Reference_1 foreign key (deptid)
                
          references Department (id) on delete restrict on update restrict;
          Department.java
          package com.many2one.bean;

          import java.io.Serializable;
          import java.util.Set;

          import javax.persistence.Column;
          import javax.persistence.Entity;
          import javax.persistence.GeneratedValue;
          import javax.persistence.GenerationType;
          import javax.persistence.Id;
          import javax.persistence.OneToMany;
          import javax.persistence.Table;

          @SuppressWarnings(
          "serial")
          @Entity
          @Table(name
          ="department",catalog="jpa_many2one")
          public class Department  implements Serializable{
              
              
          private int id;
              
          private String name;
              
          private Set<Employee> sets;
              @Id
              @GeneratedValue(strategy
          =GenerationType.AUTO)
              @Column(name
          ="id")
              
          public int getId() {
                  
          return id;
              }
              
          public void setId(int id) {
                  
          this.id = id;
              }
              @Column(name
          ="name")
              
          public String getName() {
                  
          return name;
              }
              
          public void setName(String name) {
                  
          this.name = name;
              }
              @OneToMany(mappedBy
          ="department")
              
          public Set<Employee> getSets() {
                  
          return sets;
              }
              
          public void setSets(Set<Employee> sets) {
                  
          this.sets = sets;
              }
              
              
          }
          Employee.java
          package com.many2one.bean;

          import javax.persistence.CascadeType;
          import javax.persistence.Column;
          import javax.persistence.Entity;
          import javax.persistence.GeneratedValue;
          import javax.persistence.GenerationType;
          import javax.persistence.Id;
          import javax.persistence.JoinColumn;
          import javax.persistence.ManyToOne;
          import javax.persistence.Table;

          @Entity
          @Table(name
          ="employee",catalog="jpa_many2one")
          public class Employee {
              
              
          private int id;
              
          private String name;
              
          private Department department;
              @Id
              @GeneratedValue(strategy
          =GenerationType.AUTO)
              @Column(name
          ="id")
              
          public int getId() {
                  
          return id;
              }
              
          public void setId(int id) {
                  
          this.id = id;
              }
              @Column(name
          ="name")
              
          public String getName() {
                  
          return name;
              }
              
          public void setName(String name) {
                  
          this.name = name;
              }
              @ManyToOne(cascade
          =CascadeType.ALL)
              @JoinColumn(name
          ="deptid")
              
          public Department getDepartment() {
                  
          return department;
              }
              
          public void setDepartment(Department department) {
                  
          this.department = department;
              }
              
              
          }
          persistence.xml
          <?xml version="1.0" encoding="UTF-8"?>
          <persistence xmlns="http://java.sun.com/xml/ns/persistence"
              xmlns:xsi
          ="http://www.w3.org/2001/XMLSchema-instance"
              xsi:schemaLocation
          ="http://java.sun.com/xml/ns/persistence
              http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
           version="1.0">
              
              
          <persistence-unit name="JPA_Many2OnePU" transaction-type="RESOURCE_LOCAL">
                  
          <provider>org.hibernate.ejb.HibernatePersistence</provider>
                  
          <class>com.many2one.bean.Department</class>
                  
          <class>com.many2one.bean.Employee</class>
                    
          <properties>
                      
          <property name = "hibernate.connection.driver_class" value = "com.mysql.jdbc.Driver"/>
                      
          <property name = "hibernate.connection.url" value = "jdbc:mysql://localhost:3306/jpa_many2one"/>
                      
          <property name = "hibernate.connection.username" value = "root"/>
                      
          <property name = "hibernate.connection.password" value = "root"/>
                      
          <property name = "hibernate.show_sql" value = "true"/>
                      
          <property name = "hibernate.format_sql" value = "true"/>
                    
          </properties>
              
          </persistence-unit>
            
          </persistence>
          JPAUtil.java
          package com.many2one.util;

          import javax.persistence.EntityManager;
          import javax.persistence.EntityManagerFactory;
          import javax.persistence.Persistence;

          public class JPAUtil {
              
              
          private static EntityManager entityManager;
              
          public static EntityManager getInstance(){
                  
          if(entityManager!=null){
                      
          return entityManager;
                  }
          else{
                      
          return makeInstance();
                  }
              }
              
          private static synchronized EntityManager makeInstance() {
                  
          if(entityManager==null){
                      EntityManagerFactory entityManagerFactory
          =Persistence.createEntityManagerFactory("JPA_Many2OnePU");
                      
          return entityManagerFactory.createEntityManager();
                  }
                  
          return null;
              }
          }

          @Test
              
          public void select(){
                  EntityManager entityManager
          =JPAUtil.getInstance();
                  Employee employee
          =entityManager.find(Employee.class1);
                  System.out.println(
          "雇員是:"+employee.getName());
                  System.out.println(
          "部門是:"+employee.getDepartment().getName());
              }
              
              @Test
              
          public void insert(){
                  EntityManager entityManager
          =JPAUtil.getInstance();
                  EntityTransaction entityTransaction
          =entityManager.getTransaction();
                  
          try {
                      entityTransaction.begin();
                      Department department
          =new Department();
                      department.setName(
          "軟件研發部");
                      Employee employee
          =new Employee();
                      employee.setName(
          "張三");
                      employee.setDepartment(department);
                      entityManager.persist(employee);
                      entityTransaction.commit();
                  } 
          catch (Exception e) {
                      e.printStackTrace();
                      entityTransaction.rollback();
                  }
              }
          posted on 2010-10-17 16:36 雪山飛鵠 閱讀(2631) 評論(0)  編輯  收藏 所屬分類: JPA
          主站蜘蛛池模板: 万源市| 肥城市| 科技| 开原市| 河源市| 双桥区| 九龙县| 石屏县| 朝阳区| 莫力| 沽源县| 凤城市| 维西| 元阳县| 肥东县| 高雄市| 监利县| 黄浦区| 闽清县| 平定县| 德格县| 大化| 枣阳市| 当雄县| 天津市| 靖安县| 清原| 拜泉县| 上思县| 陕西省| 滕州市| 平南县| 巫溪县| 广元市| 陆河县| 东平县| 平阳县| 青冈县| 任丘市| 晴隆县| 上栗县|