Hibernate的简单示例
首先我们新建一个项目,Java项目或者是Javaweb项目都可以,然后把hibernate需要的jar导入,我用的jar包如下:

然后新建一个实体类Teacher.java并添加get和set方法:
1 public class Teacher {
2 private String username;
3 private String password;
4 private int age;
5 public String getUsername() {
6 return username;
7 }
8 public void setUsername(String username) {
9 this.username = username;
10 }
11 public String getPassword() {
12 return password;
13 }
14 public void setPassword(String password) {
15 this.password = password;
16 }
17 public int getAge() {
18 return age;
19 }
20 public void setAge(int age) {
21 this.age = age;
22 }
23 }在Hibernate中一个实体类对应一个.hbm.xml文件,因此我们新建一个Teacher.hbm.xml文件,内容如下:
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 6 <hibernate-mapping package="com.hibernate.domain"> 7 8 <class name="Teacher" table="Teacher"> 9 <id name="username" type="java.lang.String" column="username"> 10 <generator class="assigned"/> 11 </id> 12 <property name="password" type="java.lang.String" column="password" length="50"/> 13 <property name="age" type="int" column="age" length="10"/> 14 </class> 15 16 </hibernate-mapping>
其中第9-11行代表的是主键的配置,name是指实体类中的字段,而column则是指数据库中相对应的字段。<genetator>中的class="assigned"代表主键非自动增长。下面的<property>则是配置的非主键。此文件和实体类在同一个包中。
之后我们需要在src目录下新建一个hibernate.cfg.xml文件,并将实体类对应的Teacher.hbm.xml文件导入,代码如下:
1 <!DOCTYPE hibernate-configuration PUBLIC 2 "-//Hibernate/Hibernate Configuration DTD 3.0//EN" 3 "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> 4 5 <hibernate-configuration> 6 <session-factory> 7 <!-- 配置数据库信息 --> 8 <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> 9 <property name="connection.url">jdbc:mysql://localhost:3306/test</property> 10 <property name="connection.driver_class">com.mysql.jdbc.Driver</property> 11 <property name="connection.username">root</property> 12 <property name="hibernate.connection.password"></property> 13 14 15 <!-- 导入映射文件--> 16 <mapping resource="com/hibernate/domain/Teacher.hbm.xml"/> 17 </session-factory> 18 </hibernate-configuration>
第7-12行为配置数据库的基本信息,当然大家用的时候需要改一下11、12行,改成自己数据库对应的用户名和密码。
接下来我们写一个查询的方法和插入的方法TeacherDao.java:
1 public class TeacherDao {
2 //读取配置文件
3 Configuration congif = new Configuration().configure();
4 //创建sessionFactory
5 SessionFactory sf = congif.buildSessionFactory();
6 //创建session
7 Session session = null;
8 //创建事务(Hibernate必须用事务)
9 Transaction tx = null;
10 //插入一条数据
11 public void insert(Teacher teacher) {
12 try {
13 //打开session
14 session = sf.openSession();
15 //开启事务
16 tx = session.beginTransaction();
17 //进行持久化操作(添加,删除,更新)
18 session.save(teacher);
19 //提交事务
20 tx.commit();
21 } catch (Exception e) {
22 //事务回滚
23 tx.rollback();
24 } finally {
25 if (session != null)
26 session.close();
27 }
28
29 }
30 //查询数据
31 public List<Teacher> find(String hql) {
32 List<Teacher> teacher=new ArrayList<Teacher>();
33 try {
34 session = sf.openSession();
35 tx = session.beginTransaction();
36 //使用hql语句进行查询
37 Query query=session.createQuery(hql);
38 //返回list
39 teacher=query.list();
40 tx.commit();
41 } catch (Exception e) {
42 tx.rollback();
43 } finally {
44 if (session != null)
45 session.close();
46 }
47 return teacher;
48 }
49 }当然如果我们的src目录下的hibernate.cfg.xml名称不为这个,则在第3行读取配置文件的时候需要加上配置文件的路径。我们来看一下文件的目录结构:
我们在Test.java类中进行测试,代码如下:
1 public class Test {
2
3 public static void main(String[] args) {
4 /**
5 * 利用Hibernate的save方法进行持久化操作
6 */
7 Teacher t=new Teacher();
8 t.setUsername("username4");
9 t.setPassword("root4");
10 t.setAge(20);
11 TeacherDao dao=new TeacherDao();
12 dao.insert(t);
13 /**
14 * 使用hql语句进行查询
15 * @return:将返回结果的username在控制台输出
16 */
17 String hql="from Teacher";
18 List<Teacher> teacher=dao.find(hql);
19 for (int i = 0; i < teacher.size(); i++) {
20 System.out.println(teacher.get(i).getUsername());
21 }
22 }
23
24 }当然不要忘记数据库中的表,我们可以根据Teacher.java中的字段建立,完成之后我们就可以在Test.java中运行一下看看结果了。