hibernate手動分配assigned 主鍵增長方式

一、手動分配數據庫主鍵增長方式

assigned

二、還是hibernate_basemapping項目

1、新建 User.class 類

package com.bjsxt.hibernate;

 

import java.util.Date;

 

public class User3 {

   private String id;//實體是有標識的,我們最好建立一個唯一性的標識。

   private String name;

   private String password;

   private Date createTime;

   private Date expireTime;

   public String getId() {

      return id;

    }

   public void setId(String id) {

      this.id = id;

    }

   public String getName() {

      return name;

    }

   public void setName(String name) {

      this.name = name;

    }

   public String getPassword() {

      return password;

    }

   public void setPassword(String password) {

      this.password = password;

    }

   public Date getCreateTime() {

      return createTime;

    }

   public void setCreateTime(Date createTime) {

      this.createTime = createTime;

    }

   public Date getExpireTime() {

      return expireTime;

    }

   public void setExpireTime(Date expireTime) {

      this.expireTime = expireTime;

    }

   

}

 

2、User3.hbm.xml文件如下:

<?xmlversion="1.0"?>

<!DOCTYPE hibernate-mappingPUBLIC

   "-//Hibernate/Hibernate Mapping DTD 3.0//EN"

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

<hibernate-mapping>

   <classname="com.bjsxt.hibernate.User3" >

      <idname="id" >

         <generatorclass="assigned"></generator>

     </id>

      <propertyname="name" unique="true" not-null="true"length="20"/>

      <propertyname="password" not-null="true"length="10"/>

      <propertyname="createTime"/>

      <propertyname="expireTime"/>

   </class>

</hibernate-mapping>

 

3、加入到hibernate.cfg.xml文件

<!DOCTYPE hibernate-configurationPUBLIC

   "-//Hibernate/Hibernate Configuration DTD 3.0//EN"

   "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

 

<hibernate-configuration>

   <session-factory >

       <!-- 數據庫改成hibernate_session -->

      <propertyname="hibernate.connection.url">jdbc:mysql://localhost/hibernate_basemapping</property>

      <propertyname="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>

      <propertyname="hibernate.connection.username">root</property>

      <propertyname="hibernate.connection.password">root</property>

      <propertyname="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>

      <propertyname="hibernate.show_sql">true</property>

     

      <mappingresource="com/bjsxt/hibernate/User.hbm.xml"/>

       <mappingresource="com/bjsxt/hibernate/User2.hbm.xml"/>

       <mappingresource="com/bjsxt/hibernate/User3.hbm.xml"/>

   </session-factory>

</hibernate-configuration>

 

4、執行ExportDB.xml文件,將實體類導出表

5、assigned數據庫主鍵增長方式,主鍵必須是手動分配的,如果不分配,就出錯了。

testSave3()測試方法內容如下:

public void testSave3(){

      Sessionsession=null;

      try{

         session=HibernateUtils.getSession();

         session.beginTransaction();

      

         User3user3=new User3();

         

         

            user3.setId("001");

         user3.setName("米城粒");

         user3.setPassword("123");

         user3.setCreateTime(newDate());

         user3.setExpireTime(newDate());         

         

         session.save(user3);

         session.getTransaction().commit();

      }catch(Exceptione){

         e.printStackTrace();

         session.getTransaction().rollback();

      }finally{

        HibernateUtils.closeSession(session);

      }

   

        

      }

      

三、那麼一般情況下,應該採用哪種主鍵生成策略 呢?

建議採用uuid,因爲uuid是由hibernate自動生成的32位的16進制字符串,而不是由數據庫生成的,所以它一定比數據庫生成方式要快。

可是它也有缺點,就是查找的時候要相對慢些,因爲串的查找要比數字的查找慢

 

四、readme.txt文件內容如下:

hibernate基本映射

實體類映射成表

實體類中的普通屬性映射成表字段

 

採用<class>標籤映射成數據庫表,通過<property>標籤將普通屬性映射成表字段

(普通屬性是指不包含自定義類、數組、List、集合等。

 

注意:如果實體類和實體類中的屬性和sql中的關鍵字重複,必須採用table或column重新命名

 

實體類的設計原則:

    *實現一個默認的(即無參數的)構造方法(constructor)

    *提供一個標識屬性( identifier property)可選

    *使用非final的類(可選)

        finally不能繼承,不能重寫,而Lazy方式,是生成一個實體類的子類的,這個子類繼承了實體類,所以聲明爲final是不可以的。

        

    *爲持久化字段聲明訪問器(accessors)

 

主鍵生成策略:

   uuid native assigned

發佈了14 篇原創文章 · 獲贊 19 · 訪問量 11萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章