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

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

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

    內蒙古java團隊

    j2se,j2ee開發組
    posts - 139, comments - 212, trackbacks - 0, articles - 65
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    Hibernate一對一數據關聯(二) 唯一外鍵關聯

    Posted on 2007-01-08 16:55 帥子 閱讀(2678) 評論(2)  編輯  收藏 所屬分類: j2se技術專區
    Hibernate一對一數據關聯(二) 唯一外鍵關聯
    一.單向一對一關聯
    1.數據模型如下圖所示:


    2.數據表sql
    DROP?TABLE?T_User;
    DROP?TABLE?T_Group;

    CREATE?TABLE?T_Group?(
    ???????id?
    INT?NOT?NULL?AUTO_INCREMENT
    ?????,?name?
    VARCHAR(50)
    ?????,?
    PRIMARY?KEY?(id)
    );

    CREATE?TABLE?T_User?(
    ???????id?
    INT?NOT?NULL?AUTO_INCREMENT
    ?????,?name?
    VARCHAR(50)
    ?????,?age?
    INT
    ?????,?group_id?
    INT?NOT?NULL
    ?????,?
    PRIMARY?KEY?(id)
    ?????,?
    INDEX?(group_id)
    ?????,?
    CONSTRAINT?FK_T_User_1?FOREIGN?KEY?(group_id)
    ??????????????????
    REFERENCES?T_Group?(id)
    );

    </DIV>
    3.POJO類
    TUser.java
    package?cn.blogjava.start;

    public?class?TUser??implements?java.io.Serializable?{
    ????
    //?Fields????
    ?????private?Integer?id;
    ?????
    private?Integer?age;
    ?????
    private?String?name;
    ?????
    private?TGroup?group;


    ????
    //?Constructors

    ????
    public?Integer?getAge()?{
    ????????
    return?age;
    ????}

    ????
    public?void?setAge(Integer?age)?{
    ????????
    this.age?=?age;
    ????}


    ????
    public?TGroup?getGroup()?{
    ????????
    return?group;
    ????}

    ????
    public?void?setGroup(TGroup?group)?{
    ????????
    this.group?=?group;
    ????}

    ????
    /**?default?constructor?*/
    ????
    public?TUser()?{
    ????}
    ????
    ????
    /**?constructor?with?id?*/
    ????
    public?TUser(Integer?id)?{
    ????????
    this.id?=?id;
    ????}

    ????
    //?Property?accessors

    ????
    public?Integer?getId()?{
    ????????
    return?this.id;
    ????}
    ????
    ????
    public?void?setId(Integer?id)?{
    ????????
    this.id?=?id;
    ????}

    ????
    public?String?getName()?{
    ????????
    return?this.name;
    ????}
    ????
    ????
    public?void?setName(String?name)?{
    ????????
    this.name?=?name;
    ????}
    }

    TGroup.java
    package?cn.blogjava.start;

    import?java.io.Serializable;

    public?class?TGroup?implements?Serializable?{
    ????
    ????
    private?Integer?id;
    ????
    private?String?name;
    ????
    ????
    public?Integer?getId()?{
    ????????
    return?id;
    ????}
    ????
    public?void?setId(Integer?id)?{
    ????????
    this.id?=?id;
    ????}
    ????
    public?String?getName()?{
    ????????
    return?name;
    ????}
    ????
    public?void?setName(String?name)?{
    ????????
    this.name?=?name;
    ????}
    ????
    }
    </DIV>
    3.配置文件
    hibernate.cfg.xml
    <?xml?version="1.0"?encoding="UTF-8"?>
    <!DOCTYPE?hibernate-configuration?PUBLIC
    ????????"-//Hibernate/Hibernate?Configuration?DTD?3.0//EN"
    ????????"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
    >
    <hibernate-configuration>
    ????
    <session-factory>
    ????????
    <property?name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
    ????????
    <property?name="hibernate.connection.password">1234</property>
    ????????
    <property?name="hibernate.connection.url">jdbc:mysql://localhost:3306/sample</property>
    ????????
    <property?name="hibernate.connection.username">root</property>
    ????????
    <property?name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
    ????????
    <mapping?resource="cn/blogjava/start/TUser.hbm.xml"?/>
    ????????
    <mapping?resource="cn/blogjava/start/TGroup.hbm.xml"?/>????????
    ????
    </session-factory>
    </hibernate-configuration>
    </DIV>
    TGroup.hbm.xml
    <?xml?version="1.0"?>
    <!DOCTYPE?hibernate-mapping?PUBLIC?"-//Hibernate/Hibernate?Mapping?DTD?3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
    >
    <hibernate-mapping>
    ????
    <class?name="cn.blogjava.start.TGroup"?table="T_Group"?catalog="sample">
    ????????
    <id?name="id"?type="integer">
    ????????????
    <column?name="id"?/>
    ????????????
    <generator?class="native"?/>
    ????????
    </id>
    ????????
    <property?name="name"?type="string"?column="name"?/>
    ????
    </class>
    </hibernate-mapping>
    </DIV>
    TUser.hbm.xml
    <?xml?version="1.0"?>
    <!DOCTYPE?hibernate-mapping?PUBLIC?"-//Hibernate/Hibernate?Mapping?DTD?3.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
    >
    <hibernate-mapping>
    ????
    <class?name="cn.blogjava.start.TUser"?table="T_User"?catalog="sample">
    ????????
    <id?name="id"?type="integer">
    ????????????
    <column?name="id"?/>
    ????????????
    <generator?class="native"?/>
    ????????
    </id>
    ????????
    <property?name="name"?type="string">
    ????????????
    <column?name="name"?length="100"?not-null="true"?/>
    ????????
    </property>
    ????????
    <property?name="age"?type="java.lang.Integer"?column="age"?/>
    ????????
    <many-to-one?name="group"?
    ????????????????????class
    ="cn.blogjava.start.TGroup"?
    ????????????????????column
    ="GROUP_ID"
    ??????????????????? cascade="all"
    ????????????????????unique
    ="true"?
    ?????????
    />
    ????
    </class>
    </hibernate-mapping>
    </DIV>
    4.測試代碼
    package?cn.blogjava.start;

    import?java.util.List;

    import?junit.framework.Assert;
    import?junit.framework.TestCase;

    import?org.hibernate.HibernateException;
    import?org.hibernate.Session;
    import?org.hibernate.SessionFactory;
    import?org.hibernate.Transaction;
    import?org.hibernate.cfg.Configuration;


    public?class?HibernateTest?extends?TestCase?{
    ????
    ????Session?session?=?null;

    ????protected?void?setUp()?{
    ????????try?{
    ????????????Configuration?config?=?new?Configuration().configure();
    ????????????SessionFactory?sessionFactory?=?config.buildSessionFactory();
    ????????????session?=?sessionFactory.openSession();
    ????????????
    ????????}?catch?(HibernateException?e)?{
    ????????????e.printStackTrace();
    ????????}????????
    ????}

    ????protected?void?tearDown()?{
    ????????try?{
    ????????????session.close();????????
    ????????}?catch?(HibernateException?e)?{
    ????????????e.printStackTrace();
    ????????}????????
    ????}????
    ????
    ????/**
    ?????*?對象持久化測試(Insert方法)
    ?????*/????????
    ????public?void?testInsert()?{
    ????????Transaction?tran?=?null;
    ????????try?{
    ????????
    ????????????TUser?user?=?new?TUser();
    ????????????user.setName("byf");
    ????????????user.setAge(new?Integer(26));
    ????????????
    ????????????TGroup?group?=?new?TGroup();
    ????????????group.setName("Admin");
    ????????????
    ?????????????? // 如果在配置文件中沒有cascade="all",就要先插入group信息
    ???????????//?tran?=?session.beginTransaction();????????????
    ???????????//?session.save(group);
    ???????????//?session.flush();
    ???????????//?tran.commit();
    ????????????????????????
    ????????????tran?=?session.beginTransaction();????????????????????
    ????????????//設置關聯
    ????????????user.setGroup(group);

    ?????????????? //插入user信息
    ????????????session.save(user);
    ????????????session.flush();
    ????????????tran.commit();

    ????????????Assert.assertEquals(user.getId().intValue()>0?,true);
    ????????}?catch?(HibernateException?e)?{
    ????????????e.printStackTrace();
    ????????????Assert.fail(e.getMessage());
    ????????????if(tran?!=?null)?{
    ????????????????try?{
    ????????????????????tran.rollback();
    ????????????????}?catch?(Exception?e1)?{
    ????????????????????e1.printStackTrace();
    ????????????????}
    ????????????}
    ????????}
    ????}
    ????
    ????/**
    ?????*?對象讀取測試(Select方法)
    ?????*/????????????
    ????public?void?testSelect(){
    ????????String?hql?=?"?from?TUser?where?name='byf'";
    ????????try?{
    ????????????List?userList?=?session.createQuery(hql).list();
    ????????????TUser?user?=?(TUser)userList.get(0);
    ????????????System.out.println("user?name?is?"?+?user.getName());
    ????????????System.out.println("user?group?is?"?+?user.getGroup().getName());

    ????????????Assert.assertEquals(user.getName(),?"byf");
    ????????}?catch?(Exception?e)?{
    ????????????e.printStackTrace();
    ????????????Assert.fail(e.getMessage());
    ????????}
    ????}
    }

    評論

    # re: Hibernate一對一數據關聯(二) 唯一外鍵關聯  回復  更多評論   

    2008-08-27 17:51 by qin
    怎么不行呢??

    # re: Hibernate一對一數據關聯(二) 唯一外鍵關聯  回復  更多評論   

    2009-06-21 08:56 by
    如果我想插入TUser表呢?Hibernate怎么插入?
    主站蜘蛛池模板: 在线免费视频一区| 国产精品视频免费一区二区| 亚洲伊人久久成综合人影院| 西西人体大胆免费视频| 免费一级毛片在级播放| 成人久久久观看免费毛片| 亚洲福利电影在线观看| 国内精品免费在线观看| 亚洲国产成人久久综合碰碰动漫3d| 国产免费网站看v片在线| 亚洲国产精品久久久久婷婷老年| 国产精成人品日日拍夜夜免费| 亚洲午夜在线电影| 国色精品卡一卡2卡3卡4卡免费 | 亚洲精品无码专区久久久| 国产精品综合专区中文字幕免费播放| 中文字幕亚洲图片| 久久久久免费看成人影片| 亚洲AV一二三区成人影片| 日韩免费观看视频| 国产无限免费观看黄网站| 亚洲精品中文字幕麻豆| 真实乱视频国产免费观看| 毛片基地看看成人免费| 亚洲系列中文字幕| 国产在线19禁免费观看国产| 一本大道一卡二大卡三卡免费 | 毛片免费全部免费观看| 视频一区在线免费观看| 久久精品国产亚洲AV网站| 成年女人毛片免费播放视频m| 特级毛片A级毛片免费播放| 亚洲国产精品va在线播放| 亚洲高清中文字幕免费| 国产精品亚洲色图| 亚洲福利视频一区| 国产性生交xxxxx免费| 国产一区二区免费视频| 最新亚洲人成无码网站| 亚洲欧洲日韩不卡| 国产在线观看免费不卡|