Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 989|回复: 0

[默认分类] Spring-Data-JPA整合MySQL和配置

[复制链接]
  • TA的每日心情
    开心
    2021-12-13 21:45
  • 签到天数: 15 天

    [LV.4]偶尔看看III

    发表于 2018-4-3 11:19:08 | 显示全部楼层 |阅读模式
    一、简介
      (1)、MySQL是一个关系型数据库系统,是如今互联网公司最常用的数据库和最广泛的数据库。为服务端数据库,能承受高并发的访问量。
      (2)、Spring-Data-Jpa是在JPA规范下提供的Repository层的实现,可以使用不同的实现框架如Hibernate、OpenJpa等框架进行开发,这样可以使得Repository变得简单,也解决了其与业务层的耦合性。
    本此学习我们使用MySQL+Spring-Data-Jpa搭建,Jpa实现方式使用Hibernate,数据库连接池使用dbcp进行连接
    二、项目搭建
      1、引入MySQL以及Jpa相关依赖: 

    1. <!-- spring-jdbc相关依赖 -->
    2. <dependency>
    3.     <groupId>org.springframework</groupId>
    4.     <artifactId>spring-jdbc</artifactId>
    5. </dependency>
    6. <!-- 用于连接mysql的相关依赖 -->
    7. <dependency>
    8.     <groupId>mysql</groupId>
    9.     <artifactId>mysql-connector-java</artifactId>
    10. </dependency>
    11. <!-- jpa相关的依赖 [code]包含spring-data-jpa、spring-orm 和 Hibernate 来支持 JPA
    复制代码
    -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>    [/code]

    需要引入三个依赖,jdbc为spring整合MySQL需要的依赖,第二个为MySQL的数据库驱动依赖,第三个为Spring-Data-Jpa相关的依赖包含:

    其中其包含AOP、jdbc、Spring-ORM、事务Transaction-api和Hibernate等依赖来支持。所以Jpa默认为使用Hibernate进行实现。
      2 、配置文件配置:
      配置文件我们选择.yml格式文件进行配置,并且使用dpcp2配置连接池参数:

      1)项目相关配置:

    1. server:
    2.   #配置端口号
    3.   port: 8088
    4. spring:
    5.   application:
    6.    #配置服务名称
    7.     name: cms-dept
    复制代码


    此处为配置配置服务器开启的相关信息,主要为配置服务器名称和端口
      2)MySQL相关配置

    1. spring:
    2. #数据源和jpa配置
    3.   datasource:
    4.     #数据库相关的配置url -SSL连接设置为false
    5.     url: jdbc:mysql://localhost:3306/crm?characterEncoding=utf8&useSSL=false
    6.    #配置用户名
    7.     username: ***
    8.     #配置密码
    9.     password: ***
    复制代码


    此处为数据库相关的一些配置,主要为配置数据库url、账号和密码。url后配置信息为连接MySQL的编码格式和是否启用SSL加密。
      3)DBCP相关配置 

    1. spring:
    2.     #下面为连接池相关配置
    3.     dbcp2:
    4.       #初始化连接池大小
    5.       initial-size: 10
    6.       #陪住最小连接池数
    7.       min-idle: 10      
    8.       #配置最大连接池数
    9.       max-idle: 30
    10.       #配置获取超时连接的等待时间
    11.       max-wait-millis: 30000
    12.       #配置多长时间进行一次检测,检测需要关闭的数据库连接
    13.       time-between-eviction-runs-millis: 200000
    14.       #配置连接在连接池的最小生存时间
    15.       remove-abandoned-on-maintenance: 200000
    复制代码


    主要配置为一些连接池的信息,配置详情如上注释所示。
      4)Spring-Data-Jpa依据iHibernata相关配置  

    1. spring:
    2. jpa:
    3.    #配置数据库类型
    4.     database: MYSQL
    5.    #配置是否打印sql
    6.     show-sql: true
    7.     #Hibernate相关配置
    8.    hibernate:
    9.      #配置级联等级  
    10.       ddl-auto: update
    11.      naming:
    12.        #命名策略
    13.         strategy: org.hibernate.cfg.ImprovedNamingStrategy
    14.    properties:
    15.    hibernate:
    16.         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方式进行配置:


    1. /**
    2. * @功能描述:用于MySQL相关配置的类
    3. * @author Administrator
    4. */
    5. //下面此行用来排序的注解接口,用于处理加载优先级的问题,拥有两个枚举变量
    6. @Order(Ordered.HIGHEST_PRECEDENCE)
    7. //下面此行代表此类为配置类
    8. @Configuration
    9. //下面此行代表此类开启事务管理
    10. @EnableTransactionManagement(proxyTargetClass = true)
    11. //也可以定义为类 如DeptRepository.class   也可以定义过滤器 includeFilters={ @ComponentScan.Filter(type=FilterType.ANNOTATION,value=Service.class)}
    12. @EnableJpaRepositories(basePackages="com.hzt.**.repository")
    13. public class MySQLConfig {
    14.    
    15.     @Bean
    16.     PersistenceExceptionTranslationPostProcessor persistenceExceptionTranslationPostProcessor() {
    17.         return new PersistenceExceptionTranslationPostProcessor();
    18.     }
    19. }
    复制代码


      
    1. 1)、@Order注解,用于配置类的加载优先级别,其拥有两个枚举变量:
    2.    Ordered.HIGHEST_PRECEDENCE- Integer.MIN_VALUE -最小值,拥有最高优先级
    3.    Ordered.LOWEST_PRECEDENCE -Integer.MAX_VALUE -最大值,拥有最低优先级
    4. 2)、@Configuration 注解,代表此类为配置类
    5. 3)、@EnableTransactionManagement 用于MySQL的事务管理 proxyTargetClass= true代表开启类的事务管理
    6. 4)、@EnableJpaRepositories 用于配置事务,此处以cgnl表达式表示路径,也可以定义为具体的类,例如DeptRepository.class
    7.   其子元素includeFilters可以定义事务拦截器,如includeFilters={ @ComponentScan.Filter(type=FilterType.ANNOTATION,value=Service.class)}
    8. [b]4 、ORM映射Java类相关代码:
    9. [/b] [b]1)数据库表结构
    10.   [img]http://www.itdaan.com/imgs/9/4/8/7/57/bce9929d16145ea9c04702e37c6b95bd.jpe[/img][/b]
    11.  [b] 2)实体类映射[/b]
    复制代码


    1. @Entity  //代表此类为一个表的映射entity类
    2. @Table(name="tbl_dept")  //设置对应的表名
    3. public class Dept implements Serializable{
    4.     /**
    5.      * 功能描述:序列化时候的唯一性,相应的get和set方法已经省略。
    6.      */
    7.     private static final long serialVersionUID = 1L;
    8.     /** 主键-id uuid */
    9.     @Id  //此备注代表该字段为该类的主键
    10.     @GeneratedValue(generator="system-uuid")
    11.     @GenericGenerator(name="system-uuid",strategy = "uuid")
    12.     //name - 指定对应列的名称 ,length - 最大长度
    13.     @Column(name="id",length=32) //
    14.     private String id;
    15.     /** 数字,具有唯一性 */
    16.     //nullable - 是否可以为null,默认为true   unique - 是否唯一,默认为false
    17.     @Column(name="no",nullable=false,unique=true)
    18.     private Integer no;
    19.     /** 部门名称 */
    20.     @Column(name="name",unique=true,nullable=false)
    21.     private String name;
    22.     /** 部门管理的主键-id uuid */
    23.     @Column(name="manager",unique=true,nullable=false)
    24.     private String manager;
    25.     /** 部门描述 */
    26.     @Column(name="description")
    27.     private String description;
    28.     /** 部门电话 */
    29.     @Column(name="phone")
    30.     private String phone;
    31.     /** 部门创建时间 */
    32.     @Column(name="createTime")
    33.   @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
    34.     private Date createTime;
    35.     /** 部门修改时间 */
    36.     @Column(name="editTime")
    37.   @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
    38.     private Date editTime;
    39. }
    复制代码

    1. (1)、@Entity 代表此类映射为数据库的表结构
    2. (2)、@Table(name="tbl_dept")此注解用于配置实体类与表映射的关系,name代表映射的表名
    3. (3)、 @Id注解代表此类为一个主键
    4. (4)、@GeneratedValue注解用于配置主键相关信息,generator属性用于配置生成策略有以下几种枚举值:
    5.   1、auto - 主键由程序控制 。
    6.   2、IDENTITY - 由数据库自动生成。
    7.   3、enerator -指定生成主键使用的生成器 。
    8.  4、SEQUENCE - 根据底层数据库的序列来生成主键 。
    9.   5、TABLE - 使用一个特定的数据库表来保存主键。
    10.   6、system-uuid 代表使用系统生成的uuid进行配。
    11. (5)、@Column用于配置列相关信息的注解
    12.   1、name字段用于指定映射到表结构的映射字段。
    13.   2、length代表此字段的长度约束,可以省略。
    14.   3、unique属性代表此字段是否开启唯一性约束,默认为false,唯一则为true 。
    15.   4、nullable代表此字段是否可以为空,默认为true 。 false代表不能为空 。
    16. (6)、@DateTimeFormat用于映射数据库表时间的格式。
    17. 相应的get和set方法已经省略。
    复制代码
    1.  [b]3)DeptRepository层实现[/b][b]
    2. [/b][img]http://www.itdaan.com/imgs/8/3/8/5/47/f344cbb58bd355c3b67825ac78fff032.jpe[/img]
    复制代码
    1. 如图,Respository为一个接口规范,有不同的子接口继承,每个子接口除了继承父接口所有功能外还会添加额外的方法,用于不同的实现。CrudRepository类定义了基本方法,其子类分别进行扩展。
    2. 如PagingAndSortingRepository类除了继承CrudRepository的所有方法,还额外对其进行扩展,增加了分页查找的相关方法:
    3.   Iterable<T> findAll(Sort sort);
    4.   Page<T> findAll(Pageable pageable);
    5. 而JpaRepository则是在PagingAndSortingRepository的基础上再进行扩展。
    6. [b]1、Repository层:[/b]
    7.  @Repository 代表将此类交由spring管理,并且其为一个dao层
    复制代码


    1. /**
    2. * @功能描述:用于部门表操作的dao层接口
    3. * @author Administrator
    4. */
    5. @Repository//代表此为一个dao层实现
    6. public interface DeptRepository extends JpaRepository<Dept, String>{
    7. }
    复制代码

    1. 根据实现类不同,其拥有不同的方法可调用,一般此处方法大家见名知意都能知道其用法。泛型中<Dept, String> 第一个参数代表表映射的实体类,第二个参数代表主键类型。
    复制代码
    1. [b]2、Service层实现:
    2. [/b]
    复制代码


    1. /**
    2. * @功能描述:用于部门service操作的实现类
    3. * @author Administrator
    4. */
    5. @Service
    6. public class DeptServiceImpl implements DeptService{
    7.     /** 日志处理类 */
    8.     private final Logger log = LoggerFactory.getLogger(getClass());
    9.    
    10.     @Autowired
    11.     private DeptRepository repository;
    12.    
    13.     @Override
    14.     public Dept queryById(String id) throws Exception {
    15.         try {
    16.             Dept result = repository.findOne(id);
    17.             log.info(result.toString());
    18.             return result;
    19.         }catch (Exception e) {
    20.             log.info(e.toString(),e);
    21.             throw new ServiceException("根据id查询时发生异常!");
    22.         }
    23.     }
    24. }
    复制代码

    1. 其中findOne为JpaRepository实现的方法。
    复制代码
    1. [b]3、Controller层实现:[/b]
    复制代码
    1. [/code]
    2. [code]@RestController
    3. @RequestMapping("/api/v1/dept")
    4. public class DeptController{
    5.     /** 日志记录类 */
    6.     private Logger log = LoggerFactory.getLogger(getClass());
    7.     /** 自家的service */
    8.     @Autowired
    9.     private DeptService service;
    10.    
    11.     /**
    12.      * @功能描述:根据id查询部门内容的方法
    13.      * @return Dept
    14.      */
    15.     @GetMapping("/id/get")
    16.     public Result getById( String id) throws Exception{
    17.         verify(new VerifyParam("部门id", id));
    18.         return new Result("通过id获取部门信息成功!", service.queryById(id));
    19.     }
    20. }
    复制代码

    1. [/code]
    2. 其中RestController代表此Controller为返回Json格式的控制器,@RequestMapping定义其类映射的url,此处我们接受的数据为普通String类型,如果需要接受Json类型,则需 @RequestBody String id 如此配置接受请求参数。
    3. [b]4 、测试:[/b]
    4. [b][img]http://www.itdaan.com/imgs/2/1/4/2/80/ccda6990108cd8a04464b3afcd2f8234.jpe[/img][/b]
    5. [code][b]模拟进行发送get请求,完成Spring-Data-Jpa与MySQL的整合和配置。
    6. [/b]
    复制代码
    1. [b] [/b]
    复制代码
    复制代码
    复制代码
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-4-27 05:38 , Processed in 0.401909 second(s), 50 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表