首次学习Hibernate,本文主要记录使用Hibernate建立Java与MySQL联系的详细过程,以供大家学习参考。
主要分为以下几个步骤:
一、创建Hibernate的配置文件
二、创建持久化类
三、创建对象—关系映射文件,即O-RMapping文件
四、通过Hibernate API编写访问MySQL数据库的代码
一、创建Hibernate的配置文件
1.首先导入Hibernate和JDBC的jar包,本文使用的Hibernate的jar包为旧版本:hibernate-distribution-3.3.2.GA-dist,JDBC的jar包版本为mysql-connector-java-5.1.39,由于不同版本的jar包有微小差异,为了避免由此引发的一些编译及运行错误(此类错误对初学者又比较难解决),故想要练习的同学还是以列出的版本为第一选择。
注意:jar包组成为hibernate-distribution-3.3.2.GA\lib\required的全部jar包
hibernate-distribution-3.3.2.GA\hibernate3.jar
slf4j-nop-1.5.8.jar(此jar包要单独从网上下载)
mysql-connector-java-5.1.39\mysql-connector-java-5.1.39-bin.jar
2.创建Hibernate配置文件:hibernate.cfg.xml
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<!--创建Hibernate的配置文件-->
<session-factory name="mysql">
<property name="connection.driver_class">com.mysql.jdbc.Driver</property><!--连接MySQl的驱动-->
<property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property><!--连接数据库的路径,hibernate是要连接的数据库-->
<property name="connection.username">root</property><!--数据库用户名-->
<property name="connection.password">qwe</property>
<property name="dialect">org.hibernate.dialect.MySQL5Dialect</property><!--数据库方言-->
<property name="show_sql">true</property>
<mapping resource="HibernateDemo1/Students.hbm.xml"/><!--加载映射文件-->
</session-factory>
</hibernate-configuration>
二、创建持久化类
本文建立的表很简单,只有sid和sname两个字段,其中sid设为主键
/*
* 创建持久化类
* */
public class Students {
private int sid;
private String sname;
public int getSid() {
return sid;
}
public void setSid(int sid) {
this.sid = sid;
}
public String getSname() {
return sname;
}
public void setSname(String sname) {
this.sname = sname;
}
}
三、创建对象—关系映射文件,即O-RMapping文件
<?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>
<class name="HibernateDemo1.Students" table="student">
<id name="sid" column="sid" type="int"></id><!--设置主键标示,类中的属性和表中的列对应-->
<property name="sname" column="sname" type="string"></property><!--注意:type里的类型必须小写-->
</class>
</hibernate-mapping>
四、通过Hibernate API编写访问MySQL数据库的代码
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import HibernateDemo1.Students;
public class HibernateTest {
public static void main(String[] args) {
SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();//
try {
Students s = new Students();
s.setSid(1);
s.setSname("zhangsan");
session.save(s);
tx.commit();
} catch (Exception e) {
e.printStackTrace();
}finally{
if(session!=null){
session.close();
}
}
}
}
代码想要实现的功能是:给表中插入一组值(1,zhangsan)
代码实现结果如下:
实验成功!
因为我现在刚接触Hibernate,本文所述关键部分较省略,以后学习深入之后再来填坑。。。