Hibernate的简单示例

时间:2022-04-24 11:00:12

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

Hibernate的简单示例

然后新建一个实体类Teacher.java并添加get和set方法:

 public class Teacher {
private String username;
private String password;
private int age;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}

在Hibernate中一个实体类对应一个.hbm.xml文件,因此我们新建一个Teacher.hbm.xml文件,内容如下:

 <?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.hibernate.domain"> <class name="Teacher" table="Teacher">
<id name="username" type="java.lang.String" column="username">
<generator class="assigned"/>
</id>
<property name="password" type="java.lang.String" column="password" length="50"/>
<property name="age" type="int" column="age" length="10"/>
</class> </hibernate-mapping>

其中第9-11行代表的是主键的配置,name是指实体类中的字段,而column则是指数据库中相对应的字段。<genetator>中的class="assigned"代表主键非自动增长。下面的<property>则是配置的非主键。此文件和实体类在同一个包中。

之后我们需要在src目录下新建一个hibernate.cfg.xml文件,并将实体类对应的Teacher.hbm.xml文件导入,代码如下:

 <!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration>
<session-factory>
<!-- 配置数据库信息 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="connection.url">jdbc:mysql://localhost:3306/test</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.username">root</property>
<property name="hibernate.connection.password"></property> <!-- 导入映射文件-->
<mapping resource="com/hibernate/domain/Teacher.hbm.xml"/>
</session-factory>
</hibernate-configuration>

第7-12行为配置数据库的基本信息,当然大家用的时候需要改一下11、12行,改成自己数据库对应的用户名和密码。

接下来我们写一个查询的方法和插入的方法TeacherDao.java:

 public class TeacherDao {
//读取配置文件
Configuration congif = new Configuration().configure();
//创建sessionFactory
SessionFactory sf = congif.buildSessionFactory();
//创建session
Session session = null;
//创建事务(Hibernate必须用事务)
Transaction tx = null;
//插入一条数据
public void insert(Teacher teacher) {
try {
//打开session
session = sf.openSession();
//开启事务
tx = session.beginTransaction();
//进行持久化操作(添加,删除,更新)
session.save(teacher);
//提交事务
tx.commit();
} catch (Exception e) {
//事务回滚
tx.rollback();
} finally {
if (session != null)
session.close();
} }
//查询数据
public List<Teacher> find(String hql) {
List<Teacher> teacher=new ArrayList<Teacher>();
try {
session = sf.openSession();
tx = session.beginTransaction();
//使用hql语句进行查询
Query query=session.createQuery(hql);
//返回list
teacher=query.list();
tx.commit();
} catch (Exception e) {
tx.rollback();
} finally {
if (session != null)
session.close();
}
return teacher;
}
}

当然如果我们的src目录下的hibernate.cfg.xml名称不为这个,则在第3行读取配置文件的时候需要加上配置文件的路径。我们来看一下文件的目录结构:Hibernate的简单示例

我们在Test.java类中进行测试,代码如下:

 public class Test {

     public static void main(String[] args) {
/**
* 利用Hibernate的save方法进行持久化操作
*/
Teacher t=new Teacher();
t.setUsername("username4");
t.setPassword("root4");
t.setAge(20);
TeacherDao dao=new TeacherDao();
dao.insert(t);
/**
* 使用hql语句进行查询
* @return:将返回结果的username在控制台输出
*/
String hql="from Teacher";
List<Teacher> teacher=dao.find(hql);
for (int i = 0; i < teacher.size(); i++) {
System.out.println(teacher.get(i).getUsername());
}
} }

当然不要忘记数据库中的表,我们可以根据Teacher.java中的字段建立,完成之后我们就可以在Test.java中运行一下看看结果了。