热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

Spring-Data-JPA整合MySQL和配置的方法

这篇文章主要介绍了SpringDataJPA整合MySQL和配置,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

一、简介

(1)、MySQL是一个关系型数据库系统,是如今互联网公司最常用的数据库和最广泛的数据库。为服务端数据库,能承受高并发的访问量。

(2)、Spring-Data-Jpa是在JPA规范下提供的Repository层的实现,可以使用不同的实现框架如Hibernate、OpenJpa等框架进行开发,这样可以使得Repository变得简单,也解决了其与业务层的耦合性。

本此学习我们使用MySQL+Spring-Data-Jpa搭建,Jpa实现方式使用Hibernate,数据库连接池使用dbcp进行连接

二、项目搭建

 1、引入MySQL以及Jpa相关依赖:



 org.springframework
 spring-jdbc



 mysql
 mysql-connector-java



 org.springframework.boot
 spring-boot-starter-data-jpa
 

需要引入三个依赖,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 findAll(Sort sort);
Page findAll(Pageable pageable);

而JpaRepository则是在PagingAndSortingRepository的基础上再进行扩展。

1、Repository层:

@Repository 代表将此类交由spring管理,并且其为一个dao层

/**
 * @功能描述:用于部门表操作的dao层接口
 * @author Administrator
 */
@Repository//代表此为一个dao层实现
public interface DeptRepository extends JpaRepository{

}

根据实现类不同,其拥有不同的方法可调用,一般此处方法大家见名知意都能知道其用法。泛型中 第一个参数代表表映射的实体类,第二个参数代表主键类型。

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的整合和配置。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 本文介绍了通过mysql命令查看mysql的安装路径的方法,提供了相应的sql语句,并希望对读者有参考价值。 ... [详细]
  • mysql-cluster集群sql节点高可用keepalived的故障处理过程
    本文描述了mysql-cluster集群sql节点高可用keepalived的故障处理过程,包括故障发生时间、故障描述、故障分析等内容。根据keepalived的日志分析,发现bogus VRRP packet received on eth0 !!!等错误信息,进而导致vip地址失效,使得mysql-cluster的api无法访问。针对这个问题,本文提供了相应的解决方案。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • 如何在php中将mysql查询结果赋值给变量
    本文介绍了在php中将mysql查询结果赋值给变量的方法,包括从mysql表中查询count(学号)并赋值给一个变量,以及如何将sql中查询单条结果赋值给php页面的一个变量。同时还讨论了php调用mysql查询结果到变量的方法,并提供了示例代码。 ... [详细]
  • r2dbc配置多数据源
    R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
author-avatar
一起回到我们的那个夏天
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有