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

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

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

    隨筆-126  評論-247  文章-5  trackbacks-0


     博客搬家的時候順便把文章搬過來,如果看得不是很清楚的,可以前往原博客地址:
     http://www.cnblogs.com/fancyzero/archive/2012/06/10/hibernate-many-to-one_one-to-many-annotation.html

    環(huán)境:

    Hibernate 3.3.1 
    Maven 3.0.4 
    MySQL 5.5.13 
    Myeclipse 8.6.1 

    建表語句:

    DROP TABLE IF EXISTS `t_company`;
    CREATE TABLE `t_company` (
      `companyId` int(10) unsigned NOT NULL AUTO_INCREMENT,
      `companyName` varchar(30) NOT NULL,
      PRIMARY KEY (`companyId`)
    ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=gb2312;
    
    INSERT INTO `t_company` VALUES ('1', 'Sun');
    INSERT INTO `t_company` VALUES ('2', 'Apache');
    DROP TABLE IF EXISTS `t_employee`;
    CREATE TABLE `t_employee` (
      `employeeId` int(10) unsigned NOT NULL AUTO_INCREMENT,
      `employeeName` varchar(15) NOT NULL,
      `cid` int(10) unsigned NOT NULL,
      PRIMARY KEY (`employeeId`)
    ) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=gb2312;
    
    INSERT INTO `t_employee` VALUES ('1', 'Tom', '1');
    INSERT INTO `t_employee` VALUES ('2', 'Summ', '1');
    INSERT INTO `t_employee` VALUES ('3', 'Cat', '2');
    INSERT INTO `t_employee` VALUES ('4', 'Vinylon', '1');
    INSERT INTO `t_employee` VALUES ('5', 'Dog', '2');

    目錄結(jié)構(gòu):

    Employee.java

    package com.fancy.po;
    
    import javax.persistence.CascadeType;
    import javax.persistence.Entity;
    import javax.persistence.FetchType;
    import javax.persistence.GeneratedValue;
    import javax.persistence.GenerationType;
    import javax.persistence.Id;
    import javax.persistence.JoinColumn;
    import javax.persistence.ManyToOne;
    import javax.persistence.Table;
    /**
     * -----------------------------------------
     * @文件: Employee.java
     * @作者: fancy
     * @郵箱: fancyzero@yeah.net
     * @時間: 2012-6-10
     * @描述: 實體類
     * -----------------------------------------
     */
    /**
     * 下面只說@ManyToOne,如需了解其他注解,
     * 可以參考上一篇:http://www.cnblogs.com/fancyzero/archive/2012/06/10/hibernate-one-to-one-annotation.html
     */
    @Entity
    @Table(name = "t_employee")
    public class Employee {
    
        private Integer employeeId;
        private String  employeeName;
        private Company company;
        
        @Id
        @GeneratedValue(strategy = GenerationType.AUTO)
        public Integer getEmployeeId() {
            return employeeId;
        }
        /**
         * @ManyToOne:多對一,cascade:級聯(lián),請參考上一篇
          * fetch = FetchType.LAZY,延遲加載策略,如果不想延遲加載可以用FetchType.EAGER
         */
        @ManyToOne(cascade = {CascadeType.PERSIST, CascadeType.MERGE, CascadeType.REFRESH},fetch = FetchType.LAZY)
        @JoinColumn(name = "cid")
        public Company getCompany() {
            return company;
        }
        public String getEmployeeName() {
            return employeeName;
        }
        public void setEmployeeId(Integer employeeId) {
            this.employeeId = employeeId;
        }
        public void setEmployeeName(String employeeName) {
            this.employeeName = employeeName;
        }
        public void setCompany(Company company) {
            this.company = company;
        }
    }

     

    Company.java

    package com.fancy.po;
    
    import java.util.Set;
    import javax.persistence.Entity;
    import javax.persistence.GeneratedValue;
    import javax.persistence.GenerationType;
    import javax.persistence.Id;
    import javax.persistence.OneToMany;
    import javax.persistence.Table;
    /**
     * -----------------------------------------
     * @文件: Company.java
     * @作者: fancy
     * @郵箱: fancyzero@yeah.net
     * @時間: 2012-6-10
     * @描述: 實體類
     * -----------------------------------------
     */
    /**
     * 下面只說@OneToMany,如需了解其他注解,
     * 可以參考上一篇:http://www.cnblogs.com/fancyzero/archive/2012/06/10/hibernate-one-to-one-annotation.html
     */
    @Entity
    @Table(name = "t_company")
    public class Company {
    
        private Integer companyId;
        private String  companyName;
        private Set<Employee> employees;
        
        @Id
        @GeneratedValue(strategy = GenerationType.AUTO)
        public Integer getCompanyId() {
            return companyId;
        }
        /**
         * @OneToMany 與 OneToOne相似的也用mappedBy,參考了Employee
         * 可以參考上一篇
         */
        @OneToMany(mappedBy = "company")
        public Set<Employee> getEmployees() {
            return employees;
        }
        public String getCompanyName() {
            return companyName;
        }
        public void setCompanyId(Integer companyId) {
            this.companyId = companyId;
        }
        public void setCompanyName(String companyName) {
            this.companyName = companyName;
        }
        public void setEmployees(Set<Employee> employees) {
            this.employees = employees;
        }
    }

     

    pom.xml

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
      <modelVersion>4.0.0</modelVersion>
      <groupId>com.fancy</groupId>
      <artifactId>hibernate-annotation-many-to-one-example</artifactId>
      <version>0.0.1-SNAPSHOT</version>
      <packaging>jar</packaging>
      <name>hibernate-annotation-many-to-one-example</name>
      <url>http://maven.apache.org</url>
      <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      </properties>
      
      <dependencies>
        <!-- hibernate jar -->
        <dependency>
          <groupId>org.hibernate</groupId>
          <artifactId>hibernate-entitymanager</artifactId>
          <version>3.3.1.ga</version>
        </dependency>
        <!-- hibernate annotation jar -->
        <dependency>
          <groupId>org.hibernate</groupId>
          <artifactId>hibernate-annotations</artifactId>
          <version>3.3.1.GA</version>
        </dependency>
        <!-- mysql -->
        <dependency>
          <groupId>mysql</groupId>
          <artifactId>mysql-connector-java</artifactId>
          <version>5.1.17</version>
        </dependency>
        <dependency>
          <groupId>junit</groupId>
          <artifactId>junit</artifactId>
          <version>3.8.1</version>
          <scope>test</scope>
        </dependency>
      </dependencies>
      
    </project>


    Test.java

    package com.fancy.test;
    
    import java.util.Iterator;
    import java.util.Set;
    import org.hibernate.Session;
    import org.hibernate.SessionFactory;
    import org.hibernate.cfg.AnnotationConfiguration;
    import org.hibernate.cfg.Configuration;
    import com.fancy.po.Company;
    import com.fancy.po.Employee;
    /**
     * -----------------------------------------
     * @文件: Test.java
     * @作者: fancy
     * @郵箱: fancyzero@yeah.net
     * @時間: 2012-6-10
     * @描述: 測試類
     * -----------------------------------------
     */
    public class Test {
    
        public static void main(String[] args) {
            //讀取hibernate配置,默認讀取classpath下的hibernate.cfg.xml
            Configuration conf = new AnnotationConfiguration();    
            //構(gòu)建session工廠
             SessionFactory sessionFactory = conf.configure().buildSessionFactory();
            //打開session
            Session session = sessionFactory.openSession();
            //開始事務(wù)
             session.beginTransaction();
            // * * * * * * * * * * * * * * * * * * * * * * * * * * * *
            //test1(session);   //測試 1
            //test2(session);  //測試  2
            test3(session);   //測試   3
            // * * * * * * * * * * * * * * * * * * * * * * * * * * * *
            //提交事務(wù)
             session.getTransaction().commit();
            //關(guān)閉session工廠
             sessionFactory.close();
            //關(guān)閉session
            session.close();
        }
        public static void test1(Session session){
            Company company = (Company)session.get(Company.class, 1); //發(fā)出Company的select語句
             Set<Employee> employee = company.getEmployees();         //不發(fā)出Employee的select語句
             System.out.println("Company :" + company.getCompanyName());
            System.out.println("CountSum:" + employee.size()); //Employee初次被使用,發(fā)出select語句
             Iterator<Employee> it = employee.iterator(); //Employee不再發(fā)出select語句
             while(it.hasNext()){
              System.out.println("EmployeeName:" + it.next().getEmployeeName());
            }
        }
        public static void test2(Session session){
           Company company = (Company)session.get(Company.class, 2);//發(fā)出Company的select語句
            Set<Employee> employee = company.getEmployees();        //不發(fā)出Employee的select語句
            Iterator<Employee> it = employee.iterator(); //發(fā)出Employee的select語句
            Employee e = null;
           Boolean first = false;
           while(it.hasNext()){
              e = it.next();
              if(!first){
                  System.out.println("EmployeeId:[" + e.getEmployeeId() + "] information will be change");
                  e.setEmployeeName("fancy"); //更改雇員名字
                //  session.save(e);  //發(fā)出Employee的update語句,不發(fā)出Company的update語句
                    session.save(company);    //發(fā)出Employee的update語句,不發(fā)出Company的update語句
                    first = true;
                }
                System.out.println("EmployeeName:" + e.getEmployeeName());
            }
        }
        public static void test3(Session session){
            Employee employee = (Employee)session.get(Employee.class, 1);//發(fā)出Employee的select語句
             Company  company  = (Company)session.get(Company.class, 1);//發(fā)出Company的select語句
             company.setCompanyName("Oracle"); //更改公司名字
        //  session.save(company);//發(fā)出Company的update語句,不發(fā)出Employee的update語句
             session.save(employee);//發(fā)出Company的update語句,不發(fā)出Employee的update語句
        }
    }

     



      
    posted on 2012-06-10 18:57 fancydeepin 閱讀(19565) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 嫩草在线视频www免费观看| 亚洲av乱码一区二区三区| 人人玩人人添人人澡免费| 四虎精品亚洲一区二区三区| 国产麻豆剧传媒精品国产免费| 亚洲国产日韩一区高清在线| 亚洲a级片在线观看| 亚洲成人免费网址| 亚洲av中文无码乱人伦在线咪咕| 91视频免费观看| 韩国18福利视频免费观看| 亚洲av永久无码精品天堂久久| 国产高清不卡免费在线| 亚洲AV之男人的天堂| 亚洲av一本岛在线播放| 野花高清在线电影观看免费视频 | 成年男女免费视频网站 | 免费一级毛片在播放视频| 亚洲一区二区中文| 一级毛片不卡免费看老司机| 亚洲精品无码久久久| 不卡视频免费在线观看| 国产成人免费a在线资源| 亚洲色欲色欱wwW在线| 国产成人高清精品免费软件| 毛片亚洲AV无码精品国产午夜| 久久精品国产影库免费看| 成人黄软件网18免费下载成人黄18免费视频| 亚洲综合激情六月婷婷在线观看| 亚洲免费在线视频观看| 亚洲av永久无码精品漫画| 中文在线观看国语高清免费| 亚洲AV美女一区二区三区| 欧美最猛性xxxxx免费| 亚洲精品午夜久久久伊人| 毛片免费全部免费观看| 一级特黄a大片免费| 亚洲日本在线观看| 日本成人在线免费观看| 三级网站免费观看| 亚洲天堂2016|