Hibernate学习笔记之手工创建第一个Hibernate应用

本文介绍如何使用Hibernate框架连接Java与MySQL数据库。具体步骤包括配置Hibernate、创建持久化类、定义对象关系映射文件,并通过API进行数据库操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首次学习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,本文所述关键部分较省略,以后学习深入之后再来填坑。。。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值