12.1 Spring整合Hibernate

2024-04-17 02:58

本文主要是介绍12.1 Spring整合Hibernate,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一般用某ORM框架时,会在原有ORM API基础上编写封装类方便使用。很多工作Spring替我们做了。

这里写图片描述

混合使用:
一般的CRUD使用Hibernate,数据查询用iBaits或 Spring JDBC

原来典型的Hibernate配置文件

<!-- hibernate.cfg.xml  --><?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC"-//Hibernate/Hibernate Configuration DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration><session-factory><property name="dialect">org.hibernate.dialect.MySQLDialect</property>       <!-- 数据库方言 --><property name="connection.url">jdbc:mysql://localhost:3306/db_examsystem</property><!-- 数据库连接URL --><property name="connection.username">root</property>    <!-- 数据库用户名 --><property name="connection.password">hehe</property>    <!-- 数据库用户密码 --><property name="connection.driver_class">               <!-- 数据库驱动类 -->com.mysql.jdbc.Driver</property><property name="show_sql">true</property><mapping resource="com/sanqing/po/Student.hbm.xml"/><mapping resource="com/sanqing/po/Teacher.hbm.xml"/><mapping resource="com/sanqing/po/Subject.hbm.xml"/>    </session-factory>
</hibernate-configuration>在Spring中指定配置文件:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean" 
p:configLocation="classpath:hibernate.cfg.xml" />

抛弃hibernate.cfg.xml

实体类及类的配置文件:
例如 Forum.java   Forum.hbm.xml
见下面具体的写法。。Dao层:
基类Dao  BaseDao.java
public class BaseDao {@Autowiredprivate HibernateTemplate hibernateTemplate;//  set、get 
}ForumHibernateDao.java@Repository
public class ForumHibernateDao extends BaseDao{public void addForum(Forum forum) {// 配置文件里的hibernateTemplate传递给BaseDao,正好此处可以获取getHibernateTemplate().save(forum);}public void updateForum(Forum forum) {getHibernateTemplate().update(forum);}public Forum getForum(int forumId) {return getHibernateTemplate().get(Forum.class, forumId);}public long getForumNum() {Object obj = getHibernateTemplate().iterate("select count(f.forumId) from Forum f").next();return (Long) obj;}//  特殊!!public long getForumNum2() {Long forumNum = getHibernateTemplate().execute(new HibernateCallback<Long>() {public Long doInHibernate(Session session)throws HibernateException {Object obj = session.createQuery("select count(f.forumId) from Forum f").list().iterator().next();return (Long) obj;}});return forumNum;}public List<Forum> findForumByName(String forumName) {return (List<Forum>) getHibernateTemplate().find("from Forum f where f.forumName like ?", forumName + "%");}
}配置文件 application_hibernate.xml :<context:component-scan base-package="chapter12"/>  <context:property-placeholder location="classpath:jdbc.properties" /><bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"destroy-method="close"p:driverClassName="${jdbc.driverClassName}"p:url="${jdbc.url}"p:username="${jdbc.username}"p:password="${jdbc.password}"/><!-- 为了处理BLOB/CLOB型数据  --><bean id="lobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler"lazy-init="true" /><bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"p:dataSource-ref="dataSource"p:mappingDirectoryLocations="classpath:/chapter12/domain"p:lobHandler-ref="lobHandler"><property name="hibernateProperties"><props><prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop><prop key="hibernate.show_sql">true</prop></props></property>  </bean>   <!-- 配置 HibernateTemplate--><bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate"p:sessionFactory-ref="sessionFactory"></bean>  <!-- 配置 Hibernate的事务管理器  -->   <bean id="transactionManager"class="org.springframework.orm.hibernate3.HibernateTransactionManager"p:sessionFactory-ref="sessionFactory" /> <tx:annotation-driven transaction-manager="transactionManager"/>

处理LOB类型数据

在org.springframework.orm.hibernate3.support包中,可以处理LOB数据的类有:
这里写图片描述

实体类及配置文件

--   Forum.java
@Entity
@Table(name="T_FORUM")
public class Forum implements Serializable{@Id@Column(name = "FORUM_ID")private int forumId;@Column(name = "FORUM_NAME")private String forumName;@Column(name = "FORUM_DESC")private String forumDesc;public String toString(){return ToStringBuilder.reflectionToString(this);}//  get  set
}-- Forum.hbm.xml
<hibernate-mapping auto-import="true" default-lazy="false"><class name="chapter12.domain.Forum" table="t_forum"><id name="forumId" column="forum_id"><generator class="assigned" /></id><property name="forumName" column="forum_name" /><property name="forumDesc" column="forum_desc" /></class>
</hibernate-mapping>-- Topic.java
@Entity
@Table(name="T_TOPIC")
public class Topic implements Serializable {private static final long serialVersionUID = 1L; @Id@Column(name = "TOPIC_ID")private int topicId;@Column(name = "USER_ID")private int userId;@Column(name = "TOPIC_TITLE")private String topicTitle;@Column(name = "TOPIC_TIME")private Date topicTime;// 多个Topic对应一个Forum,JoinColumn表示的是表与表之间关联的那个字段,name属性如果不写,默认是:关联表的名称+“_”+ 关联表主键的字段名@ManyToOne@JoinColumn(name = "FORUM_ID")private Forum forum;@Column(name = "TOPIC_VIEWS")private int topicViews;// 一个Topic对应多个Post@OneToMany(mappedBy = "topic", cascade = CascadeType.ALL)private List<Post> posts;private int topicReplies;// get  set
}-- Topic.hbm.xml
特别的部分:
对应@ManyToOne@JoinColumn(name = "FORUM_ID")private Forum forum;
的   
<many-to-one name="forum" column="forum_id"class="chapter12.domain.Forum" />
对应private List<Post> posts;部分的配置不会写!!-- Post.java
@Entity
@Table(name="T_POST")
public class Post implements Serializable {@Id@Column(name = "POST_ID")private int postId;@Column(name = "USER_ID")private int userId;@ManyToOne@JoinColumn(name = "TOPIC_ID")private Topic topic;@Lob@Column(name = "POST_TEXT")private String postText;@Lob@Column(name = "POST_ATTACH")private byte[] postAttach;@Column(name = "POST_TIME")private Date postTime;// get && setpublic String toString(){return ToStringBuilder.reflectionToString(this);}
}-- Post.hbm.xml
特殊部分:<property name="postText" column="post_text"        type="org.springframework.orm.hibernate3.support.ClobStringType"/><property name="postAttach" column="post_attach"         type="org.springframework.orm.hibernate3.support.BlobByteArrayType"/><many-to-one name="topic" column="topic_id"class="com.baobaotao.domain.Topic" />

这篇关于12.1 Spring整合Hibernate的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/910622

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏