Hibernate入门学习笔记

一、开发前准备
1、安装hibernate插件,在线安装即可,网上有很多教程:help
—>eclipse macketspace(或者install new software)—>搜索hibernate—>选择对应的选项在线下载安装
2、导入hibernate核心jar包,事先下载好,然后导入到lib目录下即可。
3、导入单元测试jar包:junit-4.10.jar
4、导入数据库连接jar包:mysql-connector-java.jar

二、hibernate配置文档
安装了hibernate插件后,可生成hibernate配置文档:new—>other—>hibernate—>hibernate configuration file(cfg.xml) 即可生成hibernate配置文档

详细配置文档介绍可参考博客(别人的,觉得得总结的挺好就就把链接放过来了):http://www.cnblogs.com/jqyp/archive/2010/06/28/1766851.html

hibernate简单配置文档hibernate.cfg.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>
        <!--连接数据库是用户名-->
        <property name="connection.username">user</property>
        <!--连接数据库是密码-->
        <property name="connection.password">123</property>

        <!--配置数据库的驱动程序,Hibernate在连接数据库时,需要用到数据库的驱动程序--> 
        <property name="connection.driver_class">com.mysql.jdbc.Driver </property>

        <!--设置数据库的连接url:jdbc:mysql://localhost/hibernate,其中localhost表示mysql服务器名称,此处为本机,804是数据库名-->  
        <property name="connection.url">jdbc:mysql://localhost/804</property>

        <!--hibernate.dialect 只是Hibernate使用的数据库方言,就是要用Hibernate连接那种类型的数据库服务器。--> 
        <property name="dialect">org.hibernate.dialect.MySQLDialect </property>  

        <!--是否在后台显示Hibernate用到的SQL语句,开发时设置为true,便于差错,程序运行时可以在Eclipse的控制台显示Hibernate的执行Sql语句。项目部署后可以设置为false,提高运行效率--> 
        <property name="show_sql">true </property> 

        <property name="format_sql">true</property>
        <property name="hbm2dd1.auto">create</property>

    </session-factory>
</hibernate-configuration>

三、编写一个hibernate小例子
1、创建持久化类Student.java

public class Student {
    // 持久化类的设计原则:
    // 1、公有的类
    // 2、提供公有的不带参数的默认的构造方法
    // 3、属性私有
    // 4、属性setter/getter封装

    private int sid;
    private String sname;
    private String password;

    public Student() {
    }

    public Student(int sid, String sname, String password) {
        // super();
        this.sid = sid;
        this.sname = sname;
        this.password = password;
    }

    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;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    @Override
    public String toString() {
        return "Student [sid=" + sid + ", sname=" + sname + ", password="
                + password + "]";
    }
}

2、创建对象-关系映射文件
src—>new—>other—>hibernate—>最后一个选项—>next—>选择刚刚的学生类—>自动生成Student.hbm.xml
Student.hbm.xml代码展示:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2017-3-11 11:08:16 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
<!-- 将一个实体类映射成了数据库里的一张表,这里就是将Student实体类,映射成了STUDENT这张表 -->
    <class name="hibernate.Student" table="STUDENT">
    <!-- 将实体类属性映射成数据库表里的一个字段 -->
        <id name="sid" type="int">
            <column name="SID" />
            <generator class="assigned" />
        </id>
        <property name="sname" type="java.lang.String">
            <column name="SNAME" />
        </property>
        <property name="password" type="java.lang.String">
            <column name="PASSWORD" />
        </property>
    </class>
</hibernate-mapping>

然后在hibernate.cfg.xml配置文档里加入Student.hbm.xml配置(写在标签里面:

<mapping resource="Student.hbm.xml"/>

3、创建数据库
不详细介绍。

四、使用Junit进行测试
1、几个重要的标签
@Text:测试方法
@Before:初始化方法(执行测试方法之前执行)
@After:释放资源
2、具体操作
(1)单击项目名创建一个源文件夹:new—>Source Folder
(2)在这个源文件夹里创建我们的测试类StudentTest

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;

public class StudentTest {

    private SessionFactory sessionFactory;//会话工厂
    private Session session;
    private Transaction transaction;//事物对象

    @Before
    public void init(){
        //创建配置对象
        Configuration config=new Configuration().configure();
        //创建服务注册对象
        ServiceRegistry serviceRegistry=new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry();
        //创建会话工厂对象
        sessionFactory=config.buildSessionFactory(serviceRegistry);
        //会话对象
        session=sessionFactory.openSession();
        //开启事物
        transaction=session.beginTransaction();
    }

    @After
    public void destory(){
        //提交事物
        transaction.commit();
        //关闭会话
        session.close();
        //关闭会话工厂
        sessionFactory.close();     
    }

    @Test
    public void testSaveStudent(){
        //生成一个学生对象
        Student student=new Student(1,"张三","123456");
        //保存对象进入数据库
        session.save(student);
    }
}

点击测试方法,就可以进行测试啦,测试成功的话我们可以在数据库里找到hibernate帮我们新建的一张表STUDENT。并且将我们测试方法里的那条数据保存到了数据库中。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值