ID生成策略----xml配置

id生成策略java

1.對應項目:hibernate_0400_IDmysql

2.注意:sql

    a)咱們觀察hibernate生成表的結構並非爲了未來就用它生成,(可能還有本身的擴展,好比index等)數據庫

而是爲了明白咱們應該創建什麼樣的表和實體類映射。session

 

 

3.oracle

 

 

 

id主鍵:app

1)在mysql用自增字段,用auto increatmentide

   在oracle  用 sequence測試

注意:ui

       對於類裏面的對象裏的這個值就不能夠指定它了。得靠程序(數據庫)幫我自動生成;

 

hibernate或JPA已實現這樣的能力,就是經過設置-->告訴它id怎麼生成,這樣的話,你寫程序的時候就不用設這個id了。

 

----id的生成策略。

 

 

  

    

測試類:

使用junit進行

約定俗成的  在類的後面加Test是測試類HibernateIDTest

在方法的前面加Test是測試方法

 

 

 

案例:

1.查看文檔自動生成id的

看文檔的習慣是,先找目錄,找不到再進行搜索。

 

對象/關係數據庫映射基礎(Basic O/R Mapping)有一個id

  <generator class="generatorClass"/> 

可的<generator>子元素是一個Java類的名字, 用來爲該持久化類的實例生成惟一的標識。

 

uuid  university  Unicode id  全球惟一的id-----type string

native  會根據數據庫爲oracle或是mysql進行使用sequence 或是auto_increment

 

 

設置了generator,在測試類中就不須要再進行設置了。

 

對於xml配置文件進行生成uuid

 

生成的sql

id varchar(255) not nul

 

 

代碼案例:

/hibernate_0400_ID/src/com/zhuhw/hibernate/model/Student.hbm.xml

 

Java代碼   收藏代碼
  1. <?xml version="1.0"?>  
  2. <!DOCTYPE hibernate-mapping PUBLIC  
  3.         "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
  4.         "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
  5. <!-- 找不到entity,是由於這個類沒改包名 -->  
  6. <hibernate-mapping package="com.zhuhw.hibernate.model">  
  7. <class name="Student">  
  8. <!-- id主鍵;name=id對應的是Student中的getid() -->  
  9. <id name="id"  >  
  10. <generator class="uuid"></generator>  
  11. </id>  
  12. <property name="name"/>  
  13. <property name="age" />  
  14. <!-- hibernater知道了怎麼將class與表中的字段對應到一塊兒了 -->  
  15. </class>  
  16. </hibernate-mapping>  

 

 

 

 

/hibernate_0400_ID/src/com/zhuhw/hibernate/model/Student.java

 

Java代碼   收藏代碼
  1. package com.zhuhw.hibernate.model;  
  2.    
  3. public class Student {  
  4. /*private int id; 
  5. public int getId() { 
  6. return id; 
  7. public void setId(int id) { 
  8. this.id = id; 
  9. }*/  
  10. private String id;  
  11.    
  12. public String getId() {  
  13. return id;  
  14. }  
  15. public void setId(String id) {  
  16. this.id = id;  
  17. }  
  18. public String getName() {  
  19. return name;  
  20. }  
  21. public void setName(String name) {  
  22. this.name = name;  
  23. }  
  24. public int getAge() {  
  25. return age;  
  26. }  
  27. public void setAge(int age) {  
  28. this.age = age;  
  29. }  
  30. private String name;  
  31. private int age;  
  32. }  

 

 

 

/hibernate_0400_ID/src/hibernate.cfg.xml

 

Java代碼   收藏代碼
  1. <?xml version='1.0' encoding='utf-8'?>  
  2. <!DOCTYPE hibernate-configuration PUBLIC  
  3.         "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  
  4.         "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">  
  5.    
  6. <hibernate-configuration>  
  7.    
  8.     <session-factory>  
  9.    
  10.         <!-- Database connection settings -->  
  11.         <property name="connection.driver_class">com.mysql.jdbc.Driver</property>  
  12.         <property name="connection.url">jdbc:mysql://localhost/hibernate</property>  
  13.         <property name="connection.username">root</property>  
  14.         <property name="connection.password">root</property>  
  15.    
  16.         <!-- JDBC connection pool (use the built-in) -->  
  17.         <!--<property name="connection.pool_size">1</property>-->  
  18.    
  19.         <!-- SQL dialect -->  
  20.         <property name="dialect">org.hibernate.dialect.MySQLDialect</property>  
  21.    
  22.         <!-- Enable Hibernate's automatic session context management -->  
  23.         <!--<property name="current_session_context_class">thread</property>-->  
  24.    
  25.         <!-- Disable the second-level cache  -->  
  26.         <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>  
  27.    
  28.         <!-- Echo all executed SQL to stdout -->  
  29.         <property name="show_sql">true</property>  
  30.         <property name="format_sql">true</property>  
  31.    
  32.         <!-- Drop and re-create the database schema on startup -->  
  33.         <property name="hbm2ddl.auto">update</property>  
  34.         
  35.         <mapping resource="com/zhuhw/hibernate/model/Student.hbm.xml"/>  
  36.    
  37.    <mapping class="com.zhuhw.hibernate.model.Teacher"/>    
  38.     </session-factory>  
  39.    
  40. </hibernate-configuration>  

 

 

 

/hibernate_0400_ID/test/com/zhuhw/hibernate/model/HibernateIDTest.java

 

Java代碼   收藏代碼
  1. package com.zhuhw.hibernate.model;  
  2.    
  3. import org.hibernate.Session;  
  4. import org.hibernate.SessionFactory;  
  5. import org.hibernate.cfg.AnnotationConfiguration;  
  6. import org.junit.AfterClass;  
  7. import org.junit.BeforeClass;  
  8. import org.junit.Test;  
  9.    
  10. public class HibernateIDTest {  
  11.    
  12. public static SessionFactory sf = null;  
  13. @BeforeClass  
  14. public  static void beforeClass(){  
  15. sf = new AnnotationConfiguration().configure().buildSessionFactory();  
  16. }  
  17.    
  18. @Test  
  19. public void TestID(){  
  20. Student s = new Student();  
  21. /*配置文件中使用generator 
  22. * s.setId(9); 
  23. * */  
  24. s.setName("yuzhou1");  
  25. s.setAge(1);  
  26.    
  27.    
  28. Session session = sf.openSession();  
  29.    
  30. session.beginTransaction();  
  31. session.save(s);  
  32. session.getTransaction().commit();  
  33. session.close();  
  34. }  
  35.    
  36. @AfterClass  
  37. public static void afterClass(){  
  38. sf.close();  
  39. }  
  40. }  
  41.    

 

 

運行結果:

id varchar(255) 

將id生成的是String進行存儲的。

 

先將student表drop掉

 

使用native

配置文件

<id name="id"  >

<generator class="native"></generator>

</id>

 

在java 類中

將主鍵設置爲int類型便可。

 

運行結果:

create table Student (

  id integer not null auto_increment,  

  varchar(255), age integer, primary key (id))

相關文章
相關標籤/搜索