数据的多样性,导致我们对数据访问的需求更多,出现了ORM框架
ORM框架:对象关系映射 框架。可以将代码中的对象映射到数据库中
Spring 可以整合多个ORM 框架,并且SpringData JPA 的底层实现是由Hibernate 实现
这篇笔记的主要目的是为了hibernate 的了解,在springBoot 中使用数据ORM框架是SpringData JPA但是JPA的底层实现是hibernate , 所以还是要大概了解一下,Hibernate 作为一个Orm 的框架,它都干了些什么事。
1. 类到数据表对的生成
2.使用hibernate 如何完成sql 语句的编写,完成相应增啥改查方法的执行
整个博客比较重要的两个点,就是数据表的生成的那个配置文件,和hibernate 的使用
PART ONE :spring 整合 HIbernate
spring 整合Hibernate的什么或者说,如何整合?
- 使用Spring的IOC生成Hibernate 的SessionFactory
- 让HIbernate 使用Spring的声明事务
在Hibernate.cfg.xml 文件中配置:这是在导入hibernate 之后生成的一个配置文件
可以在里面完成基本的Hibernate 配置
<hibernate-configuration>
<session-factory>
<!--配置hibernate 的基本属性: 方言,sql 语句显示格式化,生成数据表的策略-->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
<property name="hibernate.show_sql">true</property>
<property name="hibernate.format_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
</session-factory>
</hibernate-configuration>
在实体类写好之后,可以生成对应的映射文件xxx.bhn.xml
在Spring的配置文件Bean.xml 中配置 数据源,hibernate,事务(事务和AOP 相关联)
<!--配置数据源和一般的数据访问没有什么不同-->
<!--配置Hibernate的SessionFactory实例,这个实例通过Spring提供的LocalSessionFactoryBean 进行配置-->
<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<!--配置数据源属性-->
<property name="ddataSource" ref="dataSource"></property>
<!--配置hibernate配置文件(设置了基本属性的文件)-->
<property name="configLocation" value="classpath:hibernate.cfg.xml">
<!--配置hibernate 映射文件的位置和名称,可以使用通配符-->
<property name="mappingLocations" value="classpath:文件的位置">
配置事务(并且将事务和AOP集合起来)
![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/6e3de753bd7d9be6d8b7ec08940bdb37.png)
hibernate 使用:
// 进行测试的时候的问题,我们如何使用Hibernate
//获取配置文件中的sessionFactory bean
@Autowired
private SessionFactory sessionFactory;
//获取当前线程绑定的Session
public Session getSession(){
return sessionFactory.getSurrentSession();//和事务相关联
}
//测试
String Hsql = "SELECT b.stock FROM Book b WHERE b.id=?";
int staock = (int)getSession().createQuery(Hsql).setString(0,1).uniqueResult();
/**
*这几个方法的意思:
*createQuery(HSql 语句):可以理解为这个函数将我们写的Hsql 语句变成了正真的sql 语句
*setString(第几个参数/从0开始,参数的值)
*uniqueResult(): 执行什么方法