Hibernate 学习笔记一


今天学习了hibernate的一点入门知识,主要是配置domain对象和表的关系映射,hibernate的一些常用的配置,以及对应的一个向数据库插入数据的小例子。期间碰到了两个Exception。
我们在使用hibernate的时候需要引入许多jar包,如果jar包少引入了或者版本老旧就会报错,下面是我遇到的两个Exception ,第一个是因为项目缺少slf4j-api.jar和slf4j-log4j12.jar这两个jar包。第二个是因为缺少log4j.jar这个包。一般这种问题只要百度一下报错就可以找到原因,只要下载相应的包,导入项目就可以解决问题。


**1. Exception in thread "main" java.lang.IllegalAccessError: tried to access field org.slf4j.impl.StaticLoggerBinder.SINGLETON from class **org.slf4j.LoggerFactory
2. Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Logger


我亲测无误的使用到的开发包 点我下载


项目的结构图


运行结果
控制台里可以看到最后一行是执行的sql语句。

数据库中可以看到插入了Jawen112这个雇员。


主要代码和配置


测试后没问题的代码。


test.java
向数据库插入一个Employee对象

package com.vv.view;

import java.util.Date;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.*;

import com.vv.domain.Employee;
import com.vv.service.EmpoyeeService;

public class test {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		
		//我们使用hibernate完成crud操作[这里我们只见对象不见表]
		//现在不使用servcie,直接测试
		//1.创建Configuration  ,  该对象用于读取"hibernate.cfg.xml" 并完成初始化
		Configuration configuration=new Configuration().configure("hibernate.cfg.xml");                 
		//2.创建sessionfactory[],这是一个会话工厂,是一个重量级的对象
		//后面做成单态,只能有一个
		SessionFactory sessionFactory=configuration.buildSessionFactory();
		//3.创建Session 相当于jdbc中的connection  一个会话
		Session session=sessionFactory.openSession();
		//4.对hibernate而言,要求程序员,在进行增加,删除,修改的时候使用事务提交
		Transaction  transaction=session.beginTransaction();
		
		//添加一个雇员
		Employee employee1=new Employee();
		employee1.setName("Jawen112");
		employee1.setEmail("995625851@qq.com");
		employee1.setHirdate(new Date());
		//保存
		session.save(employee1);//save(employee1) 就是持久化该对象(把对象保存到了数据库中)    ->insert into....  [被hibernate封装]
		//提交
		transaction.commit();
		session.close();
	}
}

和 Employee 对应的数据库


Employee.java
Employee->雇员类(属性id,年龄,邮箱,入职日期)

package com.vv.domain;

import java.util.Date;


//建议domain对应名称首字母大写
//domain对象   javabean   pojo(plain old/ordinary java object) 简单的java对象
public class Employee {

	private Integer id;
	private String name;
	private String email;
	private Date hirdate;
	
	
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getEmail() {
		return email;
	}
	public void setEmail(String email) {
		this.email = email;
	}
	public Date getHirdate() {
		return hirdate;
	}
	public void setHirdate(Date hirdate) {
		this.hirdate = hirdate;
	}

}

Emploee.hbm.xml
这里配置domain对象和表的关系映射

<?xml version="1.0" encoding="utf-8"?>
<!-- 映射文件需要dtd来指定格式   -->
<!DOCTYPE hibernate-mapping PUBLIC
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
    
    <!-- 该文件用于配置domain对象和表的关系映射 -->
   <hibernate-mapping package="com.vv.domain"> 
      <class name="Employee" table="employee">
           <!-- id元素用于指定主键属性 -->
          <id name="id" column="id"  type="java.lang.Integer">
              <!-- 该元素用于指定主键值生成策略 hilo native increment sequence uuid-->
              <generator class="native"></generator>
          </id>
          
          <property name="name" type="java.lang.String">
              <!--数据库中的列 -->
              <column name="name" not-null="false"/>
          </property>
          
          <property name="email" type="java.lang.String">
              <column name="email" not-null="false"/>
          </property>
          
          <property name="hirdate" type="java.util.Date">
              <column name="hirdate" not-null="false"/>
          </property>
          
      
      </class>
    </hibernate-mapping>	

hibernate.cfg.xml
这里配置一些和数据库有关的配置(驱动,用户,密码,url,管理的对象映射文件即Emploee.hbm.xml 等等)

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <!-- hibernate  设计者给我们提供了一些常用的配置 -->
        <!-- 配置使用的driver -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <!-- 配置使用的用户 -->
        <property name="connection.username">xiaozhi</property>
        <!-- 配置使用的密码 -->
        <property name="connection.password">ycJWr9hBmKTb</property>
        <!-- 配置使用的url -->
        <property name="connection.url">jdbc:mysql://127.0.0.1:3306/vmalogo</property>
        <!-- 配置dialect 方言,明确告诉hibernate连接的是哪种数据库 -->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
        <!-- 显示出sql语句 -->
        <property name="show_sql">true</property>
        <!-- 指定管理的对象映射文件 -->
        <mapping  resource="com/vv/domain/Emploee.hbm.xml" />
                    
    </session-factory>
</hibernate-configuration>