一般配置的情况如下:
<?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(); //关闭会话工厂
}
}