(一)Hibernate
(1)初识Hibernate
- Hibernate
- JavaEE应用的持久层框架(轻量级)
- 是一个全自动的ORM框架(Object Relative Database Mapping)
- ORM:通过操作JavaBean对象达到操作数据库的效果
- 为什么要使用Hibernate
- 对JDBC访问数据库的操作进行了封装,简化了Dao层的编码
- 使用步骤
- 导入jar包
- 创建数据库和表
- 核心配置文件hibernate.cfg.xml
- JavaBean映射文件xx.hbm.xml
- IDEA下创建Hibernate项目
- Web Application和Hibernate,勾选Create default hibernate configuration and main class
- 在lib下导入mysql-connector.jar包以及log4j日志包
- Project Structure -> Module中导入lib下的所有包(防止com.mysql.jdbc.Driver报错)
(2)配置文件
(1)JavaBean映射
<?xml version="1.0" encoding="UTF-8" ?>
<!--约束文件-->
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<!--指定类和表名的映射关系-->
<class name="com.mio4.domain.Customer" table="cst_customer">
<!--
name:JavaBean的属性
column:表结构字段
-->
<id name="cust_id" column="cust_id">
<!-- 主键生成策略 -->
<generator class="native"/>
</id>
<!--配置其他的属性-->
<property name="cust_name" column="cust_name"/>
<property name="cust_user_id" column="cust_user_id"/>
<property name="cust_create_id" column="cust_create_id"/>
<property name="cust_source" column="cust_source"/>
<property name="cust_industry" column="cust_industry"/>
<property name="cust_level" column="cust_level"/>
<property name="cust_linkman" column="cust_linkman"/>
<property name="cust_phone" column="cust_phone"/>
<property name="cust_mobile" column="cust_mobile"/>
</class>
</hibernate-mapping>
(2)Hibernate配置
- hibernate.cfg.xml配置文件,针对MySQL
<?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>
<!--连接MySQL数据库:必须配置-->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_day01</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123456</property>
<!--数据库方言:必须配置-->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!--映射配置文件:必须配置-->
<mapping resource="com/mio4/domain/Customer.hbm.xml"/>
</session-factory>
</hibernate-configuration>
过程中报错:
org.hibernate.service.spi.ServiceException: Unable to create requested service [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment]
,一般是hibernate.cfg.xml中JDBC四个参数出错,特别注意hibernate.connection.url
- 配置可选项
<!--在控制台显示SQL语句-->
<property name="hibernate.show_sql">true</property>
<!--格式化SQL语句-->
<property name="hibernate.format_sql">true</property>
<!--每次创建一张新表,然后再进行数据库操作-->
<!--<property name="hibernate.hbm2ddl.auto">create</property>-->
<!--如果没有表则创建表,其他情况正常操作-->
<property name="hibernate.hbm2ddl.auto">update</property>
(3)数据库交互
- 一个简单的向数据库中添加一条数据的操作
//1.加载配置文件
Configuration config = new Configuration();
config.configure(); //默认加载src下的hibernate.cfg.xml文件
//2.创建SessionFactory对象
SessionFactory factory = config.buildSessionFactory();
//3.创建Session对象
Session session = factory.openSession();
//4.开启事务
Transaction transaction = session.beginTransaction();
//5.编写保存代码
Customer customer = new Customer();
customer.setCust_name("test_name2");
customer.setCust_level("1");
session.save(customer);
//6.提交事务
transaction.commit();
//7.释放资源
session.close();
(1)Session
- session的作用是执行持久化对象的CRUD操作
- 此Session不同于HttpSession中的会话技术,而是Java程序和数据库的一次交互
- session不是线程安全的,使用session之后需要session.close()释放资源
- session主要方法
- save(JavaBean对象) 保存数据
- get(JavaBean.class,主键) 查询数据
- delete(JavaBean对象):(需要是先查询出来的的对象) 删除数据
- saveOrUpdate(JavaBean对象)
- create Query(“from JavaBean对象”) 查询所有的对象,返回list集合
(2)Transaction
- 参考事务,主要方法
- commit() 事务提交
- rollback() 事务回滚