<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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

    雪山飛鵠

    溫馨提示:您的每一次轉載,體現了我寫此文的意義!!!煩請您在轉載時注明出處http://m.tkk7.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 雪山飛鵠 閱讀(2628) 評論(0)  編輯  收藏 所屬分類: JPA
    主站蜘蛛池模板: 免费人成在线观看网站品爱网 | 久久国产乱子伦精品免费午夜| 国产一精品一AV一免费孕妇| 666精品国产精品亚洲| 免费乱码中文字幕网站| 亚洲sm另类一区二区三区| 色www永久免费| 亚洲AV无码久久| 国产成人久久AV免费| 青青草原精品国产亚洲av| 24小时日本韩国高清免费| 亚洲片国产一区一级在线观看| jzzijzzij在线观看亚洲熟妇| 免费一级一片一毛片| 一级做受视频免费是看美女| 亚洲人成网7777777国产| 亚洲日韩精品国产一区二区三区| 蜜桃视频在线观看免费网址入口| 亚洲午夜理论片在线观看| 91精品免费不卡在线观看| 久久久久噜噜噜亚洲熟女综合| 中国国产高清免费av片| 亚洲AV无码AV男人的天堂| 98精品全国免费观看视频| 亚洲中文字幕久在线| 国产成人一区二区三区免费视频| 无套内谢孕妇毛片免费看看| 野花高清在线电影观看免费视频| 亚洲人成自拍网站在线观看| 四虎永久免费地址在线网站| 亚洲va久久久久| 亚洲高清无码综合性爱视频| 国产成人亚洲综合一区| 亚洲成a人片在线观看国产| 日本一区午夜艳熟免费| 亚洲精品福利你懂| 亚洲熟伦熟女新五十路熟妇| 免费一级做a爰片久久毛片潮| 国产精品亚洲片在线观看不卡| 91嫩草免费国产永久入口| 亚洲av无码偷拍在线观看|