Spring-Data-JPA整合MySQL和配置
一、简介
(1)、MySQL是一个关系型数据库系统,是如今互联网公司最常用的数据库和最广泛的数据库。为服务端数据库,能承受高并发的访问量。
(2)、Spring-Data-Jpa是在JPA规范下提供的Repository层的实现,可以使用不同的实现框架如Hibernate、OpenJpa等框架进行开发,这样可以使得Repository变得简单,也解决了其与业务层的耦合性。
本此学习我们使用MySQL+Spring-Data-Jpa搭建,Jpa实现方式使用Hibernate,数据库连接池使用dbcp进行连接
二、项目搭建
1、引入MySQL以及Jpa相关依赖:
<!-- spring-jdbc相关依赖 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
</dependency>
<!-- 用于连接mysql的相关依赖 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!-- jpa相关的依赖包含spring-data-jpa、spring-orm 和 Hibernate 来支持 JPA
-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
需要引入三个依赖,jdbc为spring整合MySQL需要的依赖,第二个为MySQL的数据库驱动依赖,第三个为Spring-Data-Jpa相关的依赖包含:
其中其包含AOP、jdbc、Spring-ORM、事务Transaction-api和Hibernate等依赖来支持。所以Jpa默认为使用Hibernate进行实现。
2 、配置文件配置:
配置文件我们选择.yml格式文件进行配置,并且使用dpcp2配置连接池参数:
1)项目相关配置:
server:
#配置端口号
port: 8088
spring:
application:
#配置服务名称
name: cms-dept
此处为配置配置服务器开启的相关信息,主要为配置服务器名称和端口
2)MySQL相关配置
spring:
#数据源和jpa配置
datasource:
#数据库相关的配置url -SSL连接设置为false
url: jdbc:mysql://localhost:3306/crm?characterEncoding=utf8&useSSL=false
#配置用户名
username: ***
#配置密码
password: ***
此处为数据库相关的一些配置,主要为配置数据库url、账号和密码。url后配置信息为连接MySQL的编码格式和是否启用SSL加密。
3)DBCP相关配置
spring:
#下面为连接池相关配置
dbcp2:
#初始化连接池大小
initial-size: 10
#陪住最小连接池数
min-idle: 10
#配置最大连接池数
max-idle: 30
#配置获取超时连接的等待时间
max-wait-millis: 30000
#配置多长时间进行一次检测,检测需要关闭的数据库连接
time-between-eviction-runs-millis: 200000
#配置连接在连接池的最小生存时间
remove-abandoned-on-maintenance: 200000
主要配置为一些连接池的信息,配置详情如上注释所示。
4)Spring-Data-Jpa依据iHibernata相关配置
spring:
jpa:
#配置数据库类型
database: MYSQL
#配置是否打印sql
show-sql: true
#Hibernate相关配置
hibernate:
#配置级联等级
ddl-auto: update
naming:
#命名策略
strategy: org.hibernate.cfg.ImprovedNamingStrategy
properties:
hibernate:
dialect: org.hibernate.dialect.MySQL5Dialect
配置依次为连接数据库类型,是否打印Sql和hIbernate级联方式,有以下几种:
1)、validate- 加载hibernate时,验证创建数据库表结构。
2)、create- 每次加载hibernate,重新创建数据库表结构,这就是导致数据库表数据丢失的原因。
3)、create-drop 加载hibernate时创建,退出是删除表结构。
4)、update-级联更新 加载hibernate自动更新数据库结构。
我们在此选择级联更新,在原有表基础上进行迭代。
命名策略有以下两种:
1)、org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy 遇到大写字母 加”_”的命名。
2)、org.hibernate.cfg.ImprovedNamingStrategy 无修改命名 。
3 、相关类进行配置:
配置类需要配置与气动类的平级目录或者子目录下,才能被配置成功,此处我们使用Java类配置取代xml方式进行配置:
/**
* @功能描述:用于MySQL相关配置的类
* @author Administrator
*/
//下面此行用来排序的注解接口,用于处理加载优先级的问题,拥有两个枚举变量
@Order(Ordered.HIGHEST_PRECEDENCE)
//下面此行代表此类为配置类
@Configuration
//下面此行代表此类开启事务管理
@EnableTransactionManagement(proxyTargetClass = true)
//也可以定义为类 如DeptRepository.class 也可以定义过滤器 includeFilters={ @ComponentScan.Filter(type=FilterType.ANNOTATION,value=Service.class)}
@EnableJpaRepositories(basePackages="com.hzt.**.repository")
public class MySQLConfig { @Bean
PersistenceExceptionTranslationPostProcessor persistenceExceptionTranslationPostProcessor() {
return new PersistenceExceptionTranslationPostProcessor();
}
}
1)、@Order注解,用于配置类的加载优先级别,其拥有两个枚举变量:
Ordered.HIGHEST_PRECEDENCE- Integer.MIN_VALUE -最小值,拥有最高优先级
Ordered.LOWEST_PRECEDENCE -Integer.MAX_VALUE -最大值,拥有最低优先级
2)、@Configuration 注解,代表此类为配置类
3)、@EnableTransactionManagement 用于MySQL的事务管理 proxyTargetClass= true代表开启类的事务管理
4)、@EnableJpaRepositories 用于配置事务,此处以cgnl表达式表示路径,也可以定义为具体的类,例如DeptRepository.class
其子元素includeFilters可以定义事务拦截器,如includeFilters={ @ComponentScan.Filter(type=FilterType.ANNOTATION,value=Service.class)} 4 、ORM映射Java类相关代码:
1)数据库表结构
2)实体类映射
@Entity //代表此类为一个表的映射entity类
@Table(name="tbl_dept") //设置对应的表名
public class Dept implements Serializable{
/**
* 功能描述:序列化时候的唯一性,相应的get和set方法已经省略。
*/
private static final long serialVersionUID = 1L; /** 主键-id uuid */
@Id //此备注代表该字段为该类的主键
@GeneratedValue(generator="system-uuid")
@GenericGenerator(name="system-uuid",strategy = "uuid")
//name - 指定对应列的名称 ,length - 最大长度
@Column(name="id",length=32) //
private String id; /** 数字,具有唯一性 */
//nullable - 是否可以为null,默认为true unique - 是否唯一,默认为false
@Column(name="no",nullable=false,unique=true)
private Integer no; /** 部门名称 */
@Column(name="name",unique=true,nullable=false)
private String name; /** 部门管理的主键-id uuid */
@Column(name="manager",unique=true,nullable=false)
private String manager; /** 部门描述 */
@Column(name="description")
private String description; /** 部门电话 */
@Column(name="phone")
private String phone; /** 部门创建时间 */
@Column(name="createTime")
@DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
private Date createTime; /** 部门修改时间 */
@Column(name="editTime")
@DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
private Date editTime;
}
(1)、@Entity 代表此类映射为数据库的表结构
(2)、@Table(name="tbl_dept")此注解用于配置实体类与表映射的关系,name代表映射的表名
(3)、 @Id注解代表此类为一个主键
(4)、@GeneratedValue注解用于配置主键相关信息,generator属性用于配置生成策略有以下几种枚举值:
1、auto - 主键由程序控制 。
2、IDENTITY - 由数据库自动生成。
3、enerator -指定生成主键使用的生成器 。
4、SEQUENCE - 根据底层数据库的序列来生成主键 。
5、TABLE - 使用一个特定的数据库表来保存主键。
6、system-uuid 代表使用系统生成的uuid进行配。
(5)、@Column用于配置列相关信息的注解
1、name字段用于指定映射到表结构的映射字段。
2、length代表此字段的长度约束,可以省略。
3、unique属性代表此字段是否开启唯一性约束,默认为false,唯一则为true 。
4、nullable代表此字段是否可以为空,默认为true 。 false代表不能为空 。
(6)、@DateTimeFormat用于映射数据库表时间的格式。
相应的get和set方法已经省略。
3)DeptRepository层实现
如图,Respository为一个接口规范,有不同的子接口继承,每个子接口除了继承父接口所有功能外还会添加额外的方法,用于不同的实现。CrudRepository类定义了基本方法,其子类分别进行扩展。
如PagingAndSortingRepository类除了继承CrudRepository的所有方法,还额外对其进行扩展,增加了分页查找的相关方法:
Iterable<T> findAll(Sort sort);
Page<T> findAll(Pageable pageable);
而JpaRepository则是在PagingAndSortingRepository的基础上再进行扩展。
1、Repository层:
@Repository 代表将此类交由spring管理,并且其为一个dao层
/**
* @功能描述:用于部门表操作的dao层接口
* @author Administrator
*/
@Repository//代表此为一个dao层实现
public interface DeptRepository extends JpaRepository<Dept, String>{ }
根据实现类不同,其拥有不同的方法可调用,一般此处方法大家见名知意都能知道其用法。泛型中<Dept, String> 第一个参数代表表映射的实体类,第二个参数代表主键类型。
2、Service层实现:
/**
* @功能描述:用于部门service操作的实现类
* @author Administrator
*/
@Service
public class DeptServiceImpl implements DeptService{
/** 日志处理类 */
private final Logger log = LoggerFactory.getLogger(getClass()); @Autowired
private DeptRepository repository; @Override
public Dept queryById(String id) throws Exception {
try {
Dept result = repository.findOne(id);
log.info(result.toString());
return result;
}catch (Exception e) {
log.info(e.toString(),e);
throw new ServiceException("根据id查询时发生异常!");
}
}
}
其中findOne为JpaRepository实现的方法。
3、Controller层实现:
@RestController
@RequestMapping("/api/v1/dept")
public class DeptController{
/** 日志记录类 */
private Logger log = LoggerFactory.getLogger(getClass());
/** 自家的service */
@Autowired
private DeptService service; /**
* @功能描述:根据id查询部门内容的方法
* @return Dept
*/
@GetMapping("/id/get")
public Result getById( String id) throws Exception{
verify(new VerifyParam("部门id", id));
return new Result("通过id获取部门信息成功!", service.queryById(id));
}
}
其中RestController代表此Controller为返回Json格式的控制器,@RequestMapping定义其类映射的url,此处我们接受的数据为普通String类型,如果需要接受Json类型,则需 @RequestBody String id 如此配置接受请求参数。
4 、测试:
模拟进行发送get请求,完成Spring-Data-Jpa与MySQL的整合和配置。
Spring-Data-JPA整合MySQL和配置的更多相关文章
- Spring Boot (五)Spring Data JPA 操作 MySQL 8
一.Spring Data JPA 介绍 JPA(Java Persistence API)Java持久化API,是 Java 持久化的标准规范,Hibernate是持久化规范的技术实现,而Sprin ...
- Springboot spring data jpa 多数据源的配置01
Springboot spring data jpa 多数据源的配置 (说明:这只是引入了多个数据源,他们各自管理各自的事务,并没有实现统一的事务控制) 例: user数据库 global 数据库 ...
- Spring Boot 2.x基础教程:Spring Data JPA的多数据源配置
上一篇我们介绍了在使用JdbcTemplate来做数据访问时候的多数据源配置实现.接下来我们继续学习如何在使用Spring Data JPA的时候,完成多数据源的配置和使用. 添加多数据源的配置 先在 ...
- Spring Boot使用Spring Data Jpa对MySQL数据库进行CRUD操作
只需两步!Eclipse+Maven快速构建第一个Spring Boot项目 构建了第一个Spring Boot项目. Spring Boot连接MySQL数据库 连接了MySQL数据库. 本文在之前 ...
- Spring Boot2 系列教程 (七) | 使用 Spring Data JPA 访问 Mysql
前言 如题,今天介绍 Spring Data JPA 的使用. 什么是 Spring Data JPA 在介绍 Spring Data JPA 之前,首先介绍 Hibernate . Hibernat ...
- Spring Boot 2.x基础教程:使用Spring Data JPA访问MySQL
在数据访问这章的第一篇文章<Spring中使用JdbcTemplate访问数据库> 中,我们已经介绍了如何使用Spring Boot中最基本的jdbc模块来实现关系型数据库的数据读写操作. ...
- Spring Data JPA 整合Spring
1.1 Spring Data JPA 与 JPA和hibernate之间的关系 JPA是一套规范,内部是有接口和抽象类组成的.hibernate是一套成熟的ORM框架,而且Hibernate实现 ...
- 使用Spring Boot 和Spring Data JPA访问mysql数据库
在Spring中使用JdbcTemplate是一种基本的数据访问方式,但是仍然需要较多的代码,为了解决这些大量枯燥的数据操作语句,我们可以使用ORM框架,比如:Hibernate,通过整合Hibern ...
- Spring Data JPA 整合Spring 第二篇
主要是在CustomerDao中去写一些代码,在调用Query中去用SQL 例如 public interface CustomerDao extends JpaRepository<Custo ...
- Spring Data Jpa 详解 (配置篇)
前言: JPA全称Java Persistence API,即Java持久化API,它为Java开发人员提供了一种对象/关系映射工具来管理Java应用中的关系数据,结合其他ORM的使用,能达到简化开发 ...
随机推荐
- luogu【P2753】[USACO4.3]字母游戏Letter Game
这个题...一开始看了很久题目(并且问了机房几个大佬)才明白题意.. (原题入口) 题意 大概是一开始给你一些字母出现的次数 你之后组成的单词(最多两个单词)每个字母出现次数 必须小于或等于标准(st ...
- UOJ207:共价大爷游长沙
题面 UOJ Sol 神题 给每个点对随机一个权值,把这两个点的权值异或上这个随机的值 用\(LCT\)维护子树信息,若子树异或和为所有点对的异或和那么就是答案 大常数代码 # include < ...
- [ZJOI2007]时态同步
题目描述 小Q在电子工艺实习课上学习焊接电路板.一块电路板由若干个元件组成,我们不妨称之为节点,并将其用数字1,2,3….进行标号.电路板的各个节点由若干不相交的导线相连接,且对于电路板的任何两个节点 ...
- iOS开发--XMPPFramework--用户登录(三)
创了一个XMPP即时通讯交流群140147825,欢迎大家来交流~我们是一起写代码的弟兄~ 我们在第一篇文章中,已经介绍了Openfire服务器的搭建等环境的配置, 第二篇文章中,导入了XMPPFra ...
- 对java的Thread的理解
最好不适用线程的子线程,直接调用线程,然后用rannable接口 然后如果要公用一个参数,就是公用资源的时候,一定要在run方法的前面加上synchronized 例子 猫和狗喝同一杯水(共用资源的问 ...
- 删除项目中的.pyc文件
在编写python项目的时候,往往会生成很多的.pyc文件,但是在我们提交代码的时候这些.pyc文件又是不必要的,所以需要对项目里面的.pyc文件进行清理.再此,经过我的查阅资料和尝试,分享出以下方法 ...
- python实现一般最小二乘系统辨识方法
问题: 对于一个未知参数的系统,往往需要用到系统辨识的方法,例如对于一个单输入单输出系统: Z(k)+a1*Z(k-1)+a2*Z(k-2)=b1*U(k-1)+b2*U(k-2)+V(k) 其中:V ...
- WordPress制作一个首字母排序的标签页面
很早就想制作这样一个页面了,废话不多说, 先看看效果:传送门 在网上找了很多的代码,试了很久,修改了一些代码,最终就达到了现在的效果. 实现方法:(里面增加了缓存功能,打开页面更快,对数据进行了缓存, ...
- Unity3D打包 将发布的exe文件打包成一个Windows安装文件(自解压文件)
Unity打包Standalone时 会出现一个exe文件和一个data文件夹 可是我们平常见过的软件 基本没有这种像这种结构的 一般都是一个安装文件,然后点击安装,选择路径,生成快捷方式- 本篇博客 ...
- pycharm+selenium搭建环境之no module named 'selenium'异常解决
在pycharm上搭建python+selenium自动化测试环境时,遇到一个很坑的问题:no moduel named 'selenium' 如下图: 解决方法: 1.查看你的python是否正确安 ...