1.在src下创建hibernate 配置文件
2.配置hibernate配置文件
<?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/db_hibernate</property>
<property name="connection.username">root</property>
<property name="connection.password"></property>
<!-- 配置hibernate 基本信息 -->
<!-- 数据库所使用的方言 -->
<!--<property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>-->
<property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
<!-- 是否在控制台输出sql -->
<property name="show_sql">true</property>
<!-- 是否对输出的SLQ进行格式化 -->
<property name="format_sql">true</property>
<!-- 是否自动生成数据库表 -->
<property name="hbm2ddl.auto">update</property>
<!-- 引入映射文件 -->
<mapping resource="com/java00123/model/Student.hbm.xml"/>
</session-factory>
</hibernate-configuration>
2-1:
主要配置项:
1.数据库连接的基本信息,驱动,连接串,用户名和密码。
2.数据库使用的方言,注意注释的那个,5.7myslq用放开的那个。
出现的异常,参考 MySQL server version for the right syntax to use near 'type=InnoDB' at line x
3.是否在控制台输出SQL
4.SQL格式化
5.自动生成数据库表
6.引入映射文件
3.创建model类
4.生成对应的hbm.xml文件
在student 类上右键 new -
一直下一步下一步,生成完成
修改一下id的生成方式
native 使用本地数据库的方式,自增
5.新建一个JUnit Test Case
package com.java00123.test;
import java.util.Date;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import com.java00123.model.Student;
public class Test {
@org.junit.Test
public void test() {
System.out.println("测试begin");
//1.创建一个SessionFactory对象
SessionFactory sessionFactory = null;
//1-1.创建Configuration对象:对应Hibernate基本配置信息,和对象关系映射信息
Configuration configuration = new Configuration().configure();
//2.创建sessionFactory 对象
sessionFactory = configuration.buildSessionFactory();
//2.创建一个session对象。
Session session = sessionFactory.openSession();
//3.开启事务
Transaction transaction = session.beginTransaction();
//4.执行保存操作
Student student = new Student("张三", 20, new Date());
session.save(student);
//5.提交事物。
transaction.commit();
//6.关闭session
session.close();
//7.关闭sessionFactory对象。
sessionFactory.close();
System.out.println("测试完毕");
}
}
6.右键运行
数据库中自动创建表,和数据。