hibernate的配置文件的配置

一般配置的情况如下:

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate?user=root&password=q7231012</property>
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <!--配置数据库方言,hibernate可以针对特殊的数据库进行优化-->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

        <!--是否把hibernate运行时的sql语句输出到控制台-->
        <property name="show_sql">true</property>
        <!--sql语句输出之后是否进行排版-->
        <property name="format_sql">true</property>
        <!--可以帮助由Java代码生成数据库脚本,进而生成具体的表结构:
            主要有四个属性:
            1.create——先删除原有表,再新建表后插入数据
            2.update——在原有表的基础上插入数据
            3.create-drop——先创建再删除
            4.validate——对原来的表进行验证(如果现在的表结构和原有的表结构不同,那么就不会创建表)-->
        <property name="hbm2ddl.auto">create</property>

        <!--默认的数据库表前缀-->
        <property name="default_schema">hibernate</property>

        <!--配置current session-->
        <property name="hibernate.current_session_context_class">thread</property>

        <mapping resource="entity/Students.hbm.xml"/>
        <mapping class="entity.Students"/>


        <!-- DB schema will be updated if needed -->
        <!-- <property name="hbm2ddl.auto">update</property> -->
    </session-factory>
</hibernate-configuration>


在这里,默认的数据表前缀改变的只是查询语句的前缀,而正真在数据库中的表示不会有前缀的。

在进过上述配置之后,就可以创建一个实体类来设计和数据库中数据表的映射了(当然,你如果用的是intellij的话,那么实体类是自动生成的)。在创建好实体对象之后,要说一下如何使用hibernate框架操作数据库了,这里需要注意的是前面配置的current session:

package dao;

import entity.Address;
import entity.Students;
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 java.util.Date;

/**
 * Created by raid on 2016/5/14.
 */
public class StudentsLogic {

    private SessionFactory sessionFactory;
    private Session session;
    private Transaction transaction;

    public void init() {
        //创建配置对象,获取hibernate.cfg.xml配置文件的信息
        Configuration config = new Configuration().configure();
        //创建服务创建对象,创建和销毁都相当耗费资源,通常一个系统内一个数据库只创建一个
        ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry();
        //创建会话工厂对象,类似于JDBC的Connection
        sessionFactory = config.buildSessionFactory(serviceRegistry);
        //创建会话对象的两种方式:
        //1.openSession
//        session = sessionFactory.openSession();
        //2.getCurrentSession,需要在配置文档中配置current session=thread
        /**
         * 如果获取session的方法是openSession(),关闭session的时候必须是session.close(),
         * 如果session获取通过getCurrentSession()获得的Session提交时自动关闭,其不用在session.close(),
         * 如果在调用session.close().其相当于session关闭两次 所以会出现Session was already closed异常
         */
        session = sessionFactory.getCurrentSession();
        //开启事务
        transaction = session.beginTransaction();

    }

    public void execute() {
        Students s = new Students("小小黑", "男", new Date(), "广东");
        Address ad = new Address("524394", "18826252094", "湛江");
        s.setAd(ad);
        //保存对象进入数据库
        session.save(s);
    }

    public void destroy() {
        transaction.commit(); //提交事务
//        session.close(); //关闭会话
        sessionFactory.close(); //关闭会话工厂
    }

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值