Hibernate教程 class1

来源:互联网 发布:网络教育美术学 编辑:程序博客网 时间:2024/05/12 09:18
你还在为对数据库操作的复杂烦心吗?你还在看sql语句的使用规则吗?
Hibernate都可以帮你解决。。
做过j2ee开发的骚年们对s2sh都不会陌生吧。H就是hibernate。
现在博主就带你初尝hibernate。
首先我们需要了解hibernate是什么,他能做什么?
先看百度百科
hibernate
简单来说hibernate就是在数据库和事务之间封装了一层,我们通过hibernate提供的接口来操纵数据库。
它能使我们更加简单和方便的操纵数据库。
现在我们可以来做我们的第一个hibernate项目了。

首先我们要使用hibernate,就要在项目中导入hibernate的包,细心的博主已经为你们准备好了。
hibernate包
hibernate的原理就是把Java的model和数据库中的表互相映射。
我们首先要建立一个javabean的类
我建立了一个student的model类。
package com.wyy.model;

public class Student {

private long id;
private String name;
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;
}
}
这个student类不需要我解释了吧。。。。

现在我们需要建立hibernate的配置文件,文件名为hibernate.cfg.xml
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

    <session-factory>

        <!--数据库连接设置 -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>
        <property name="connection.username">root</property>
        <property name="connection.password">123456</property>

       
        <!-- 方言 -->
        <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
        <!-- 控制台显示SQL -->
        <property name="show_sql">true</property>

        <!-- 自动更新表结构 -->
        <property name="hbm2ddl.auto">update</property>
        
  <mapping resource="com/wyy/model/Student.hbm.xml"/>

    </session-factory>

</hibernate-configuration>


下面解释一下
   <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>
        <property name="connection.username">root</property>
        <property name="connection.password">123456</property>
这些是连接数据库的配置文件。连接过mysql数据库的人都不会陌生吧。。。

<!-- 方言 -->
<property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!-- 控制台显示SQL -->
<property name="show_sql">true</property>

第一个是使我们的数据格式更加完备,第二个会在控制台输出sql语句,方便我们检查。
<mapping resource="com/wyy/model/Student.hbm.xml"/>
表示我们的对应规则,就是Java类和数据库table的对应规则。
 下面我们还需要为我们的student建立一个对应关系,也就是上面的com/wyy/model/Student.hbm.xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.wyy.model">

<class name="Student" table="t_student">
<id name="id" column="stuId">
<generator class="native"></generator>
</id>
<property name="name"></property>
</class>

</hibernate-mapping>
最后我们测试一下我们的程序是否正确
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;

import com.wyy.model.Student;

public class StudentTest {

public static void main(String[] args) {
Configuration configuration=new Configuration().configure(); // 实例化配置文件
ServiceRegistry serviceRegistry=new StandardServiceRegistryBuilder().applySettings(configuration.getProperties()).build(); // 实例化服务登记
   SessionFactory sessionFactory=configuration.buildSessionFactory(serviceRegistry); // 获取Session工厂
   Session session=sessionFactory.openSession(); // 生成一个session
   session.beginTransaction(); // 开启事务
   
   Student s=new Student();
   s.setName("张三");
   session.save(s);
   
   session.getTransaction().commit(); // 提交事务
   session.close(); // 关闭session
   sessionFactory.close(); // 关闭session工厂
}
}

Hibernate就是那么简单。。。后面我会为大家继续带来hibernate的深度介绍,。。。。
1 0
原创粉丝点击