Hibernate 、多表关联映射-组件关联映射(component)
生活随笔
收集整理的這篇文章主要介紹了
Hibernate 、多表关联映射-组件关联映射(component)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
組件關聯映射可以將一些簡小的數據與主題放在一個表中,例如firstName 和LastName這兩個結合在一起可以組成一個名字,但是再分別將這兩個再建一個表就不太合適了,這個時候可以用到組件關聯映射;
hibernate.cfg.xml:
<hibernate-configuration><session-factory name="sessionFactory"><property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property><property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property><property name="hibernate.connection.url">jdbc:mysql://localhost:3306/spring?useUnicode=true&characterEncoding=UTF-8</property><property name="hibernate.connection.username">root</property><property name="hibernate.connection.password"></property><property name="hibernate.show_sql">true</property><property name="hibernate.format_sql">true</property><property name="hibernate.hbm2ddl.auto">update</property><mapping resource="cn/hbm/Person2.hbm.xml" /></session-factory> </hibernate-configuration>Person: public class Person2 {private Integer id;private Name name;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public Name getName() {return name;}public void setName(Name name) {this.name = name;}}name: public class Name {private String firstName;private String lastName;public String getFirstName() {return firstName;}public void setFirstName(String firstName) {this.firstName = firstName;}public String getLastName() {return lastName;}public void setLastName(String lastName) {this.lastName = lastName;} } hbm.xml <hibernate-mapping package="cn.model"><class name="Person2" table="PERSON2"><id name="id" column="ID"><generator class="native"></generator></id><component name="name"><property name="firstName" column="FIRST_NAME" /><property name="lastName" column="LAST_NAME" /></component></class> </hibernate-mapping>
public void saveZujian(){Session session=null;Transaction tran=null;try{Person2 person=new Person2();Name name=new Name();name.setFirstName("jack");name.setLastName("tomson");person.setName(name);session=HibernateSessionFactory.getSession();tran=session.beginTransaction();session.save(person);tran.commit();}catch(Exception e){if(session!=null){session.close();}}}
執行保存以后可看到生成的SQL
確實創建在一張表中了。
執行查詢:
public Person2 getPersonById(Integer id){Session session=null;try{session=HibernateSessionFactory.getSession();return (Person2)session.get(Person2.class, id);}catch(Exception e){if(session!=null){session.close();}}return null;}總結
以上是生活随笔為你收集整理的Hibernate 、多表关联映射-组件关联映射(component)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: U3D 通过预置对象实现手动创建精灵
- 下一篇: Unix哲学,Microservices