结合HSQLDB测试Hibernate实例


一、数据库结构

  1. createtable User ( 
  2. idinteger not null
  3. namevarchar(255), 
  4. passvarchar(255),       
  5. primarykey (id) 
  6. )

 二、建立测试实例

1、 新建普通java项目

2、 项目下新建lib文件夹(放置引用jar包)

3、db(放置hsqlDB的数据库文件)文件夹

4、解压hibernate文件夹,将hibernate-release-4.0.1.Final\lib\required目录下的jar文件拷贝到项目的lib下,将hsqldb.jar(下载地址http://hsqldb.org/)拷贝到lib目录下,并引入到工程

(3、4也可建立用户库,再引入项目)

5、 项目Src目录下hibernate建立连接数据库的配置文件 hibernate.cfg.xml

 
  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <!DOCTYPE hibernate-configuration 
  3.    PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN" 
  4.    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> 
  5. <hibernate-configuration> 
  6.     <session-factory> 
  7.         <!-- 是否将运行期生成的SQL输出到日志以供调试 --> 
  8.         <property name="show_sql">true</property> 
  9.         <!-- SQL方言,这里设定的是HSQL --> 
  10.         <property name="dialect">org.hibernate.dialect.HSQLDialect</property> 
  11.         <!-- JDBC驱动程序 --> 
  12.         <property name="connection.driver_class">org.hsqldb.jdbcDriver 
  13.         </property> 
  14.         <!-- JDBC URL,User为数据库名 ; hsqldb.write_delay=false持久化 --> 
  15.         <property name="connection.url"> jdbc:hsqldb:file:./db/User;hsqldb.write_delay=true 
  16.         </property> 
  17.         <!-- 设置数据库中的表用hibernate自动建立,一般不需要不断重新建表 --> 
  18.         <property name="hibernate.hbm2ddl.auto">create</property> 
  19.         <!-- 数据库用户名 --> 
  20.         <property name="connection.username">sa</property> 
  21.         <!-- 数据库密码 --> 
  22.         <property name="connection.password"></property> 
  23.         <!-- 指定User的映射文件,这个地方应该在建立文件后添加到此处 --> 
  24.         <mapping resource="<SPAN style="BACKGROUND-COLOR: rgb(255,0,0)">com/hibernate/test/User.hbm.xml</SPAN>/> 
  25.     </session-factory> 
  26. </hibernate-configuration> 

6、 新建包:com.hibernate.test 以及包下的实体类user.java.实体通数据库映射文件User.hbm.xml、测试类Test.java

7、 实体类属性要同数据库字段名称相同,并有set和get方法 

 
  1. public class User { 
  2.     private long id; 
  3.     private String name; 
  4.     private String pass; 
  5.     public long getId() { 
  6.         return id; 
  7.     } 
  8.     public void setId(long id) { 
  9.         this.id = id; 
  10.     } 
  11.     public String getName() { 
  12.         return name; 
  13.     } 
  14.     public void setName(String name) { 
  15.         this.name = name; 
  16.     } 
  17.     public String getPass() { 
  18.         return pass; 
  19.     } 
  20.     public void setPass(String pass) { 
  21.         this.pass = pass; 
  22.     }     

 8、 实体类数据库映射文件一般以 实体类名.hbm.xml命名:内容

 
  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">     
  3. <hibernate-mapping> 
  4.    <class name="<SPAN style="BACKGROUND-COLOR: rgb(255,0,0)">com.hibernate.test.User</SPAN>table="User"> 
  5.        <id name="id"> 
  6.            <generator class="increment"/> 
  7.        </id> 
  8.        <property name="name"/> 
  9.        <property name="pass" />     
  10.    </class> 
  11. </hibernate-mapping> 

 9、.hbm.xml中对应的实体类位置要写正确

<class name="com.hibernate.test.User" table="User">

 

10、 User.hbm.xml 添加到hibernate.cfg.xml中:使用全路径(包括包名)

<!-- 指定User的映射文件,这个地方应该在建立文件后添加到此处 -->

<mapping resource="com/hibernate/test/User.hbm.xml" />

11、 建立测试文件Test.java

 
  1. public class Test { 
  2.      public static void main(String[] args) { 
  3.       try { 
  4.        SessionFactory sf = new Configuration().configure() 
  5.          .buildSessionFactory(); 
  6.        Session session = sf.openSession(); 
  7.        Transaction tx = session.beginTransaction(); 
  8.            User user = new User(); 
  9.            user.setName("李雷"); 
  10.            user.setPass("123456"); 
  11.            session.save(user); 
  12.        tx.commit(); 
  13.        session.close(); 
  14.        
  15.       } catch (HibernateException e) { 
  16.        e.printStackTrace(); 
  17.       } 
  18.      } 
  19.     }

 12、正确执行程序

  • 1
  • 2
  • 下一页

相关内容