xml配置方式:
tb_user
字段名 主键 类型 描述 id pk int 编号 first_name varchar(50) 姓 last_name varchar(50) 名 birthday Date 出生年月package domain;
import java.util.Date;
public class User {
private int id;
private Name name;
private Date birthday;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public Name getName() {
return name;
}
public void setName(Name name) {
this.name = name;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
}
package domain; 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; } }
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping SYSTEM "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="domain"> <class name="User" table="`tb_user`"> <id name="id" column="`id`"> <generator class="native"> </generator> </id> <component name="name" class="Name"> <property name="firstName" column="first_name"></property> <property name="lastName" column="last_name"></property> </component> <property name="birthday"></property> </class> </hibernate-mapping>
<!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="dialect">org.hibernate.dialect.MySQLDialect</property> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <property name="connection.url">jdbc:mysql:///user</property> <property name="connection.username">root</property> <property name="connection.password">mysqladmin</property> <property name="show_sql">true</property> <property name="hbm2ddl.auto">create</property> <mapping resource="domain/User.hbm.xml"/> </session-factory> </hibernate-configuration>
package test;
import java.util.Date;
import org.hibernate.Transaction;
import org.hibernate.classic.Session;
import dao.HibernateUtil;
import domain.Name;
import domain.Teacher;
import domain.User;
public class Component {
public static void main(String[] args) {
add();
}
static void add(){
Session session = null;
Transaction tx = null;
try {
Name name = new Name();
name.setFirstName("chen");
name.setLastName("muzhen");
User user = new User();
user.setName(name);
user.setBirthday(new Date());
session = (Session) HibernateUtil.getSession();
tx = session.beginTransaction();
session.save(user);
tx.commit();
} catch (Exception e) {
// TODO: handle exception
}finally{
if(session != null){
session.close();
}
}
}
}
Annotation配置方式:
用户和信息
分析:在用户表中有id name age address属性
package com.zchen.hibernate.component; import javax.persistence.Embedded; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.Table; @Entity @Table(name="T_PERSON_INFO") public class Person { private int id; private String name; private Info info; @Embedded public Info getInfo() { return info; } public void setInfo(Info info) { this.info = info; } @Id @GeneratedValue public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
package com.zchen.hibernate.component; public class Info { private int age; private String address; public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } }
<?xml version="1.0"?> <!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="connection.url">jdbc:mysql:///db_czbk_hibernate</property> <property name="connection.username">root</property> <property name="connection.password">1234</property> <property name="dialect">org.hibernate.dialect.MySQLDialect</property> <property name="hbm2ddl.auto">create</property> <property name="current_session_context_class">thread</property> <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property> <property name="show_sql">true</property> <mapping class="com.zchen.hibernate.component.Person"/> </session-factory> </hibernate-configuration>
package com.zchen.hibernate;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
import org.junit.Test;
public class Snippet {
@Test
public void testSchemaExport(){
new SchemaExport(new AnnotationConfiguration().configure()).create(true, true);
}
}