Hibernate之入门案例
2015-06-02 10:47
176 查看
对于Java语言的应用程序,都采用面向对象(OO)的思想来开发,而目前主流的数据库仍然是面向关系型的,它们之间的发展仍不协调,于是就出现了ORM(Object/Relation Mapping,对象/关系数据库映射)框架。ORM框架可作为面向对象编程语言和关系型数据库之间的桥梁。目前主流的ORM框架有:JPA、Hibernate、ibatis和TopLink。本章主要对Hibernate的用法做简要的说明。
创建一个Hibernate例子主要分为以下几步:
1、创建一个Java Project;
2、导入Hibernate jar包;
3、创建hibernate.cfg.xml配置文件;
4、创建持久化类;
5、创建对象-关系映射文件;
6、通过Hibernate API编写访问数据库的代码。
具体步骤如下:
1、创建一个Hibernate工程,并导入hibernate、sql驱动、以及junit,结构图(完整)如下:
![](http://img.blog.csdn.net/20150602125041273?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveHFzeTIwMDg=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
2、创建hibernate.cfg.xml配置文件
3、创建持久化类 Student.java
4、创建对象-关系映射文件
5、通过Hibernate API编写访问数据库的代码
本例使用junit测试类,包含@Before、@After和@Test三个方法,首先执行@Before方法完成执行前的初始化操作,然后执行@Test方法,最后执行@After的关闭操作。
创建一个Hibernate例子主要分为以下几步:
1、创建一个Java Project;
2、导入Hibernate jar包;
3、创建hibernate.cfg.xml配置文件;
4、创建持久化类;
5、创建对象-关系映射文件;
6、通过Hibernate API编写访问数据库的代码。
具体步骤如下:
1、创建一个Hibernate工程,并导入hibernate、sql驱动、以及junit,结构图(完整)如下:
2、创建hibernate.cfg.xml配置文件
<?xml version="1.0" encoding="UTF-8"?> <!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="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property> <property name="connection.url">jdbc:sqlserver://127.0.0.1;databaseName=test</property> <property name="connection.username">sa</property> <property name="connection.password">12345</property> <property name="dialect">org.hibernate.dialect.SQLServer2012Dialect</property> <property name="hbm2ddl.auto">update</property> <property name="format_sql">true</property> <property name="show_sql">true</property> <mapping resource="com/Student.hbm.xml"/> </session-factory> </hibernate-configuration>
3、创建持久化类 Student.java
package com; import java.util.Date; public class Student { private int id;//学号 private String name;//姓名 private String gender;//性别 private Date date;//出生日期 Student(){} public Student(int id, String name, String gender, Date date) { this.id = id; this.name = name; this.gender = gender; this.date = date; } 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; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public Date getDate() { return date; } public void setDate(Date date) { this.date = date; } @Override public String toString() { return "Student [id=" + id + ", name=" + name + ", gender=" + gender + ", date=" + date + "]"; } }
4、创建对象-关系映射文件
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com"> <class name="Student" table="student"> <id name="id"> <generator class="increment"></generator> </id> <property name="name"/> <property name="gender"/> <property name="date"/> </class> </hibernate-mapping>
5、通过Hibernate API编写访问数据库的代码
本例使用junit测试类,包含@Before、@After和@Test三个方法,首先执行@Before方法完成执行前的初始化操作,然后执行@Test方法,最后执行@After的关闭操作。
import java.util.Date; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.junit.After; import org.junit.Before; import org.junit.Test; import com.Student; public class studentTest { private SessionFactory sessionFactory; private Session session; private Transaction transaction; @Before public void init(){ //创建配置对象 Configuration configuration=new Configuration().configure(); //创建服务注册对象 ServiceRegistry registry=new ServiceRegistryBuilder() .applySettings(configuration.getProperties()) .buildServiceRegistry(); //创建会话工厂对象 sessionFactory=configuration.buildSessionFactory(registry); //创建会话对象 session=sessionFactory.openSession(); transaction=session.beginTransaction(); } @After public void destory(){ transaction.commit();//提交事务 session.close();//关闭会话 sessionFactory.close();//关闭会话工厂 } @Test public void save(){ //生成学生对象 Student s=new Student(1, "Mary", "女", new Date()); //保存对象进入数据库 session.save(s); } }
相关文章推荐
- 谈谈自己对js闭包,执行上下文,作用域链,活动对象AO,变量对象VO的理解
- 后台request获得所有参数(当你不知道它包含什么参数)
- 我所了解的chrome
- UIImage 按照指定宽度等比例裁切
- (转)Boyer-Moore算法
- Mysql的数据类型
- 第三节---nginx轻缓存安装与站点配置
- gcc-linaro-arm-linux-gnueabihf
- 论技术、组织债务
- #pragma预处理命令【转】
- 你可能不知道console强大
- FBX Software Development Kit
- JSON字符串写法和使用
- Pool of Argument Topics 21-30
- 深入理解linux i节点(inode)
- DP备份软件cell manager连接不上
- DP备份软件cell manager连接不上
- DP备份软件cell manager连接不上
- 严重: Exception starting filter struts2解决方法!
- TNS-12535: TNS:operation timed out