结合HSQLDB测试Hibernate实例
一、数据库结构
- createtable User (
- idinteger not null,
- namevarchar(255),
- passvarchar(255),
- primarykey (id)
- )
|
二、建立测试实例
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
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE hibernate-configuration
- PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
- "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
- <hibernate-configuration>
- <session-factory>
-
- <property name="show_sql">true</property>
-
- <property name="dialect">org.hibernate.dialect.HSQLDialect</property>
-
- <property name="connection.driver_class">org.hsqldb.jdbcDriver
- </property>
-
- <property name="connection.url"> jdbc:hsqldb:file:./db/User;hsqldb.write_delay=true
- </property>
-
- <property name="hibernate.hbm2ddl.auto">create</property>
-
- <property name="connection.username">sa</property>
-
- <property name="connection.password"></property>
-
- <mapping resource="<SPAN style="BACKGROUND-COLOR: rgb(255,0,0)">com/hibernate/test/User.hbm.xml</SPAN>" />
- </session-factory>
- </hibernate-configuration>
|
6、 新建包:com.hibernate.test 以及包下的实体类user.java.实体通数据库映射文件User.hbm.xml、测试类Test.java
7、 实体类属性要同数据库字段名称相同,并有set和get方法
- public class User {
- private long id;
- private String name;
- private String pass;
- public long getId() {
- return id;
- }
- public void setId(long id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public String getPass() {
- return pass;
- }
- public void setPass(String pass) {
- this.pass = pass;
- }
- }
|
8、 实体类数据库映射文件一般以 实体类名.hbm.xml命名:内容
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
- <hibernate-mapping>
- <class name="<SPAN style="BACKGROUND-COLOR: rgb(255,0,0)">com.hibernate.test.User</SPAN>" table="User">
- <id name="id">
- <generator class="increment"/>
- </id>
- <property name="name"/>
- <property name="pass" />
- </class>
- </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
- public class Test {
- public static void main(String[] args) {
- try {
- SessionFactory sf = new Configuration().configure()
- .buildSessionFactory();
- Session session = sf.openSession();
- Transaction tx = session.beginTransaction();
- User user = new User();
- user.setName("李雷");
- user.setPass("123456");
- session.save(user);
- tx.commit();
- session.close();
-
- } catch (HibernateException e) {
- e.printStackTrace();
- }
- }
- }
|
12、正确执行程序
评论暂时关闭