Posted on 2008-09-01 16:43
∪∩BUG 阅读(915)
评论(1) 编辑 收藏 所属分类:
Hibernate学习笔记
关于如何配置请参看:Hibernate学习笔记(一)--用MyEclipse 6.5+MySQL 5.0的环境跑起来
准备:建表
用MySQL在名为STMS数据库中建表personx
src/org.lxh.hibernate2.Personx.java
1
package org.lxh.hibernate2;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
/** *//**
4
* @author ∪∩BUG E-mail: tidelgl@163.com
5
* @version Aug 31, 2008 9:56:51 AM @ POJO类
6
*/
7data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
8
//实现复合主键应满足的要求:1.本类必须实现Serializable 接口
9data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class Personx implements java.io.Serializable
{
10data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
11
private PersonxId id;
12
private int age;
13data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
14data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public Personx()
{
15
}
16data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
17data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public PersonxId getId()
{
18
return this.id;
19
}
20data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
21data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setId(PersonxId id)
{
22
this.id = id;
23
}
24data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
25data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public int getAge()
{
26
return age;
27
}
28data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
29data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setAge(int age)
{
30
this.age = age;
31
}
32
}
通过Hibernate反向工程建立personx表与Personx类的映射
首先调出DB Browser视图(Windows—view show—other—MyEclipse datebase—DB Browser)—展开MySQL_localhost至表person—右键表personx—Hibernate Reverse Engineering
src/org.lxh.hibernate2.PersonxId.java
1
package org.lxh.hibernate2;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3
import org.apache.commons.lang.builder.EqualsBuilder;
4
import org.apache.commons.lang.builder.HashCodeBuilder;
5
import org.lxh.hibernate1.Personx;
6data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
7data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
/** *//**
8
* @author ∪∩BUG E-mail: tidelgl@163.com
9
* @version Aug 31, 2008 9:56:51 AM @ 复合主键类
10
*/
11
//实现复合主键应满足的要求:
12
//1.本类必须实现Serializable 接口
13
//2.复写equals(比较对象)和hashCode(取得Hash编码)方法(可用commons-lang-2.4.jar来复写,
14
//下载:http://apache.mirror.phpchina.com/commons/lang/binaries/commons-lang-2.4-bin.zip)
15data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class PersonxId implements java.io.Serializable
{
16data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
17
// Fields
18data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
19
private String name;
20
private String phone;
21data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
22
// Constructors
23data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
24data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//** default constructor */
25data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public PersonxId()
{
26
}
27data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
28data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//** full constructor */
29data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public PersonxId(String name, String phone)
{
30
this.name = name;
31
this.phone = phone;
32
}
33data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
34
// Property accessors
35data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
36data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getName()
{
37
return this.name;
38
}
39data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
40data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setName(String name)
{
41
this.name = name;
42
}
43data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
44data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public String getPhone()
{
45
return this.phone;
46
}
47data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
48data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void setPhone(String phone)
{
49
this.phone = phone;
50
}
51data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
52
// 修改复写equals的方法
53data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public boolean equals(Object obj)
{
54data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (this == obj)
{
55
return true;
56
}
57data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
58
// 如果不是Personx的实例
59data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (!(obj instanceof Personx))
{
60
return false;
61
}
62
PersonxId p = (PersonxId) obj;
63
return new EqualsBuilder().append(this.name, p.getName()).append(
64
this.phone, p.getPhone()).isEquals();
65
}
66data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
67
//修改复写hashCode的方法
68data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public int hashCode()
{
69
return new HashCodeBuilder().append(this.name).append(
70
this.phone).toHashCode();
71
}
72data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
73
}
src/org.lxh.hibernate2.PersonxOperate.java
1
package org.lxh.hibernate2;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
4
import org.hibernate.Session;
5
import org.hibernate.cfg.Configuration;
6data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
7data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
/** *//**
8
* @author ∪∩BUG E-mail: tidelgl@163.com
9
* @version Aug 31, 2008 9:56:51 AM
10
* @ 具体操作Hibernate的类
11
*/
12data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class PersonxOperate
{
13
// 在Hibernate中所有的操作都是通过Session来完成
14
private Session session;
15data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
16
// Session 是一个接口,必须实例化
17
// 在构造方法中实例实化Session对象
18data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public PersonxOperate()
{
19
// 找到Hibernae配置文件,从全局文件中取出SessionFactory,从sessionFactory中取出一个session
20
this.session = new Configuration().configure().buildSessionFactory()
21
.openSession();
22
}
23data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
24
// 所有的操作都是通过Session进行
25
// (1)增加操作
26data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public void insert(Personx p)
{
27
// 将数据存放到数据库中
28
this.session.save(p);
29data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
30
// 事务提交
31
this.session.beginTransaction().commit();
32
}
33
}
34data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
src/org.lxh.hibernate2.Test.java
1
package org.lxh.hibernate2;
2data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
3data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
4data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
5data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
/** *//**
6
* @author ∪∩BUG E-mail: tidelgl@163.com
7
* @version Aug 31, 2008 9:54:16 AM
8
* @测试类
9
*/
10data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class Test
{
11data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
12data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
/** *//**
13
* @param args
14
*/
15data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
public static void main(String[] args)
{
16
Personx p = new Personx();
17
PersonxId pk = new PersonxId();
18
19
//name,phone在表中是主键当插入值为空时将无法插入
20
// p.setAge(4);
21
// p.setName("Hibernate");
22
// p.setPhone("123456");
23
24
p.setAge(2);
25
pk.setName("MySQL");
26
pk.setPhone("87654");
27
p.setId(pk);
28
PersonxOperate po = new PersonxOperate();
29
po.insert(p);
30
}
31data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
32
}
33data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
src/org.lxh.hibernate2.Personx.hbm.xml
1
xml version="1.0" encoding="utf-8"?>
2
DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
3
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
4data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
7
<hibernate-mapping>
8
<class name="org.lxh.hibernate2.Personx" table="personx"
9
catalog="stms">
10
14
<composite-id name="id" class="org.lxh.hibernate2.PersonxId">
15
<key-property name="name" type="java.lang.String">
16
<column name="name" length="100" />
17
key-property>
18
<key-property name="phone" type="java.lang.String">
19
<column name="phone" length="50" />
20
key-property>
21
composite-id>
22
<property name="age" type="java.lang.Integer">
23
<column name="age" />
24
property>
25
class>
26
hibernate-mapping>
27data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
src/hibernate.cfg.xml
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">
5data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
6data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
7
<hibernate-configuration>
8data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
9
<session-factory>
10
<property name="connection.username">rootproperty>
11
<property name="connection.url">
12
jdbc:mysql://localhost:3306/STMS
13
property>
14
<property name="dialect">
15
org.hibernate.dialect.MySQLDialect
16
property>
17
<property name="myeclipse.connection.profile">
18
MySql_localhost
19
property>
20
<property name="connection.password">rootproperty>
21
<property name="connection.driver_class">
22
com.mysql.jdbc.Driver
23
property>
24
<property name="show_sql">trueproperty>
25data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
26
27
<mapping resource="org/lxh/hibernate2/Personx.hbm.xml" />
28data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
29
session-factory>
30data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
31
hibernate-configuration>
例子结构:
data:image/s3,"s3://crabby-images/8956a/8956a3660ca409bf0b77f5efe6764f8480a1ba1e" alt=""