spring-data详解之spring-data-jpa:简单三步快速上手spring-data-jpa开发
前言:
基于spring framework 4.x或spring boot 1.x开发环境
务必注意以下版本问题:
Spring framework4.x(Spring boot1.x)对应spring-data1.x
Spring framework5.x(Spring boot2.x)对应spring-data2.x
一、依赖
需要jpa 1.x,hibernate 5.x,spring-data-commons,spring-data-jpa
maven方式:
- <dependency>
- <groupId>org.hibernate.javax.persistence</groupId>
- <artifactId>hibernate-jpa-2.1-api</artifactId>
- <version>1.0.2.Final</version>
- </dependency>
- <dependency>
- <groupId>org.hibernate</groupId>
- <artifactId>hibernate-core</artifactId>
- <version>5.2.16.Final</version>
- </dependency>
- <dependency>
- <groupId>org.hibernate</groupId>
- <artifactId>hibernate-entitymanager</artifactId>
- <version>5.2.16.Final</version>
- </dependency>
- <dependency>
- <groupId>org.springframework.data</groupId>
- <artifactId>spring-data-jpa</artifactId>
- <version>1.11.11.RELEASE</version>
- </dependency>
二、环境配置
注意两个扫描器(一个是po实体类扫描,还有一个是dao层接口扫描)
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:context="http://www.springframework.org/schema/context"
- xmlns:tx="http://www.springframework.org/schema/tx"
- xmlns:jpa="http://www.springframework.org/schema/data/jpa"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context.xsd
- http://www.springframework.org/schema/tx
- http://www.springframework.org/schema/tx/spring-tx.xsd
- http://www.springframework.org/schema/data/jpa
- http://www.springframework.org/schema/data/jpa/spring-jpa.xsd">
- <!-- eguid博客所有原创文章均采用知识共享署名-相同方式共享 3.0 中国大陆许可协议进行许可。如有转载请注明博客地址:https://blog.csdn.net/eguid_1/article/details/80018676-->
- <!-- druid连接池 -->
- <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
- <property name="driverClassName" value="${jdbc.driverClassName}" />
- <property name="url" value="${jdbc.url}" />
- <property name="username" value="${jdbc.username}" />
- <property name="password" value="${jdbc.password}" />
- <property name="maxActive" value="${jdbc.maxActive}" />
- <property name="initialSize" value="${jdbc.initialSize}" />
- <property name="maxWait" value="${jdbc.maxWait}" />
- <property name="maxIdle" value="${jdbc.maxIdle}" />
- <property name="minIdle" value="${jdbc.minIdle}" />
- <property name="removeAbandoned" value="${jdbc.removeAbandoned}" />
- <property name="removeAbandonedTimeout" value="${jdbc.removeAbandonedTimeout}" />
- <property name="testWhileIdle" value="${jdbc.testWhileIdle}" />
- <property name="validationQuery" value="${jdbc.validationQuery}"/>
- <property name="validationQueryTimeout" value="${jdbc.validationQueryTimeout}" />
- <property name="timeBetweenEvictionRunsMillis" value="${jdbc.timeBetweenEvictionRunsMillis}" />
- <property name="numTestsPerEvictionRun" value="${jdbc.numTestsPerEvictionRun}" />
- <!-- 打开PSCache,并且指定每个连接上PSCache的大小 -->
- <property name="poolPreparedStatements" value="false" />
- <property name="maxPoolPreparedStatementPerConnectionSize" value="20" />
- <!-- 配置监控统计拦截的filters -->
- <property name="filters" value="stat,wall"/>
- <property name="connectionProperties" value="druid.stat.slowSqlMillis=5000" />
- </bean>
- <!-- JPA工厂对象 -->
- <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
- <property name="dataSource" ref="dataSource" />
- <!-- 扫描此包下的所有Entity,进行ORM映射(这里的实体类包路径需要修改) -->
- <property name="packagesToScan" value="cc.eguid.xxx.pojo.po" />
- <property name="persistenceProvider">
- <bean class="org.hibernate.jpa.HibernatePersistenceProvider" />
- </property>
- <property name="jpaVendorAdapter">
- <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
- <property name="generateDdl" value="false" />
- <property name="database" value="MYSQL" />
- <property name="databasePlatform" value="org.hibernate.dialect.MySQLDialect" />
- <property name="showSql" value="true" />
- </bean>
- </property>
- <property name="jpaDialect">
- <bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect" />
- </property>
- <property name="jpaPropertyMap">
- <map>
- <entry key="hibernate.query.substitutions" value="true 1, false 0" />
- <entry key="hibernate.default_batch_fetch_size" value="16" />
- <entry key="hibernate.max_fetch_depth" value="2" />
- <entry key="hibernate.generate_statistics" value="true" />
- <entry key="hibernate.bytecode.use_reflection_optimizer" value="true" />
- <entry key="hibernate.cache.use_second_level_cache" value="false" />
- <entry key="hibernate.cache.use_query_cache" value="false" />
- </map>
- </property>
- </bean>
- <!-- 使用声明式事务管理 -->
- <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true" />
- <!-- JPA事务管理器 -->
- <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
- <property name="entityManagerFactory" ref="entityManagerFactory"/>
- </bean>
- <!--扫描 JPA持久化接口,spring-data-jpa会自动生成实现类(这里的repostory接口包路径需要修改)-->
- <jpa:repositories base-package="cc.eguid.xxx.dao" entity-manager-factory-ref="entityManagerFactory" transaction-manager-ref="transactionManager"/>
- </beans>
三、实体类和Repository接口
(1)编写dao层接口(不需实现类,spring-data-jpa会自动生成实现类)
- import org.springframework.data.repository.CrudRepository;
- /**
- * spring-data-jpa自动生成实现类,简化dao层开发
- * @author eguid
- *
- */
- public interface UserRepository extends CrudRepository<GameUserinfo, Integer>{
- GameUserinfo findByUsername(String username);
- }
(2)自动生成的ORM映射Entity(用JPA生成工具生成的)
- /**
- * The persistent class for the game_userinfo database table.
- *
- */
- @Entity
- @Table(name="userinfo")
- @NamedQuery(name="Userinfo.findAll", query="SELECT g FROM Userinfo g")
- public class Userinfo extends BaseEntity {
- private static final long serialVersionUID = 1L;
- @Id
- @GeneratedValue(strategy=GenerationType.AUTO)
- @Column(unique=true, nullable=false)
- private Integer userid;
- private Timestamp createtime;
- @Column(length=50)
- private String nickname;
- @Column(length=100)
- private String password;
- private int type;
- @Column(length=50)
- private String username;
- //bi-directional many-to-many association to Roleinfo
- @ManyToMany
- @JoinTable(
- name="userrole"
- , joinColumns={
- @JoinColumn(name="userid", nullable=false)
- }
- , inverseJoinColumns={
- @JoinColumn(name="roleid", nullable=false)
- }
- )
- private List<roleinfo> roleinfos;
- public Userinfo() {
- }
- public Integer getUserid() {
- return this.userid;
- }
- public void setUserid(Integer userid) {
- this.userid = userid;
- }
- public Timestamp getCreatetime() {
- return this.createtime;
- }
- public void setCreatetime(Timestamp createtime) {
- this.createtime = createtime;
- }
- public String getNickname() {
- return this.nickname;
- }
- public void setNickname(String nickname) {
- this.nickname = nickname;
- }
- public String getPassword() {
- return this.password;
- }
- public void setPassword(String password) {
- this.password = password;
- }
- public int getType() {
- return this.type;
- }
- public void setType(int type) {
- this.type = type;
- }
- public String getUsername() {
- return this.username;
- }
- public void setUsername(String username) {
- this.username = username;
- }
- public List<Roleinfo> getRoleinfos() {
- return this.roleinfos;
- }
- public void setRoleinfos(List<Roleinfo> roleinfos) {
- this.roleinfos = roleinfos;
- }
- }
四、总结
1、添加依赖(添加spring-data及spring-data-jpa依赖包)
2、配置jpa环境(配置dao扫描路径和实体类扫描路径)
3、编写实体类和dao层接口(如果是简单的单表增删改查操作,直接继承CrudRepository接口即可,基本不需要写代码)
jpa单表操作基本无可挑剔,涉及多表操作需要手写hql语句或jpa
实体类是用工具生成的,所以实际上只需要写一个dao接口即可
spring-data详解之spring-data-jpa:简单三步快速上手spring-data-jpa开发的更多相关文章
- spring事务详解(二)简单样例
系列目录 spring事务详解(一)初探事务 spring事务详解(二)简单样例 spring事务详解(三)源码详解 spring事务详解(四)测试验证 spring事务详解(五)总结提高 一.引子 ...
- spring事务详解(三)源码详解
系列目录 spring事务详解(一)初探事务 spring事务详解(二)简单样例 spring事务详解(三)源码详解 spring事务详解(四)测试验证 spring事务详解(五)总结提高 一.引子 ...
- Spring学习(一)-----Spring 模块详解
官方下载链接:http://repo.spring.io/release/org/springframework/spring/ Spring 模块详解: Core 模块 spring-beans-3 ...
- Spring RestTemplate详解
Spring RestTemplate详解 1.什么是REST? REST(RepresentationalState Transfer)是Roy Fielding 提出的一个描述互联系统架构风格 ...
- Spring配置文件详解 – applicationContext.xml文件路径
Spring配置文件详解 – applicationContext.xml文件路径 Java编程 spring的配置文件applicationContext.xml的默 ...
- spring配置文件详解--真的蛮详细
spring配置文件详解--真的蛮详细 转自: http://book.51cto.com/art/201004/193743.htm 此处详细的为我们讲解了spring2.5的实现原理,感觉非常 ...
- 【转载】Spring AOP详解 、 JDK动态代理、CGLib动态代理
Spring AOP详解 . JDK动态代理.CGLib动态代理 原文地址:https://www.cnblogs.com/kukudelaomao/p/5897893.html AOP是Aspec ...
- J2EE进阶(四)Spring配置文件详解
J2EE进阶(四)Spring配置文件详解 前言 Spring配置文件是用于指导Spring工厂进行Bean生产.依赖关系注入(装配)及Bean实例分发的"图纸".Java EE程 ...
- spring事务详解(五)总结提高
系列目录 spring事务详解(一)初探事务 spring事务详解(二)简单样例 spring事务详解(三)源码详解 spring事务详解(四)测试验证 spring事务详解(五)总结提高 一.概念 ...
随机推荐
- FZU 2124 FOJ 2124 吃豆人【BFS】
Problem 2124 吃豆人 Accept: 134 Submit: 575 Time Limit: 1000 mSec Memory Limit : 32768 KB Probl ...
- 开发ActiveX控件调用另一个ActiveX系列1——开发一个MFC ActiveX控件
ActiveX开发的教程有很多,我也从中受益匪浅,例如以下这几篇: 基本教程:http://www.cnblogs.com/guenli/articles/1629915.html 注意事项:http ...
- android之Context对各种服务的管理
经常,当我们须要用到服务的时候能够通果Context来获取:Context.getSystemService(name):比方:当我们想知道当前电话状态(来电/去电/sim卡状态等)时候,我们能够通过 ...
- 【Java】使用@Value @Reource或@Autowire依赖 (值) 注入时出现NPE的排查方法
首先想说明的是,@Value @Resource和@Autowire虽然都是用于依赖注入的Annotation,但是二者是有区别的. 1 Resource不依赖于Spring,后者相反,因此为了减少以 ...
- web翻译——插件
很多时候,可能我们web项目中需要的只是机械式的翻译,并不需要什么利用xml或者js json等等实现逼真翻译,那样工作量太大.这时候可能你就需要这几款小工具来帮助你.当然,如果 对翻译或者你的项目外 ...
- [项目构建 十一]babasport 购物车的原理及实现.
今天来开始写一下关于购物车的东西, 这里首先抛出四个问题: 1)用户没登陆用户名和密码,添加商品, 关闭浏览器再打开后 不登录用户名和密码 问:购物车商品还在吗? 2)用户登陆了用户名密码,添加商品, ...
- jQuery中slideToggle()的详细使用方法和解释
$(selector).slideToggle(speed,callback) 参数 speed和callback Speed 可选.规定元素从隐藏到显示的速度,默认‘normal’可能 ...
- python 基础 5.4 类的私有属性和私有方法
一. 类的私有变量和私有方法 1> 在python 中可以通过在属性变量名前,加上双下划线定义属性为私有属性 2>特殊变量命名 a. _xx 以单下划线开头的表示的是protect ...
- 网页直播、微信直播技术解决方案:EasyNVR与EasyDSS流媒体服务器组合之区分不同场景下的easynvr
近期遇到好多客户咨询关于实现微信直播.或者是将直播页面集成进入自己项目中. 该方案的主要目的:完成在公网一直进行内网摄像头的RTMP/HLS直播! 实现方案的具体实现: EasyNVR+EasyDSS ...
- 我的Android进阶之旅------>对Java中注释/**@hide*/的初步认识
今天写一个调节系统背光亮度的时候,参考了Android中的Setting源码,在源码中有这么一段代码: private static final int MAXIMUM_BACKLIGHT = and ...