一、手動分配數據庫主鍵增長方式
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