zoukankan      html  css  js  c++  java
  • spring-boot2

    JPA全称Java Persistence API.JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中。
    JPA(Java Persistence API)是Sun官方提出的Java持久化规范。它为Java开发人员提供了一种对象/关系映射工具来管理Java应用中的关系数据。
    
    持久化(Persistence),即把数据(如内存中的对象)保存到可永久保存的存储设备中(如磁盘)。持久化的主要应用是将内存中的对象存储在的数据库中,或者存储在磁盘文件中、XML数据文件中等等。
        持久化是将程序数据在持久状态和瞬时状态间转换的机制。
        JDBC就是一种持久化机制。文件IO也是一种持久化机制。
    
    “规范”: 所谓的规范意指明文规定或约定俗成的标准。如:道德规范、技术规范,公司管理规范。
        那么“持久化规范”就是Sun针对持久化这一层操作指定的规范,如果没有指定JPA规范,那么新起的框架就随意按照自己的标准来了,那我们开发人员就没法把我们的经历全部集中在我们的业务层上,而是在想如何进行兼容,这种情况有点像Android开发,Android本身有官方的SDK,但是由于SDK过于开源了,结果导致很多厂商基于SDK二次开发,但是兼容性就不是很好,最好的例子就是Android的头像上传,就是一件很烦人的事情。好了,JPA就介绍到这里。
    
    这里引用百度百科的话hibernate:
    Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。
    
    什么是Spring Data JPA?
    Spring Data是一个开源框架,JPA只是这个框架中的一个模块。单纯使用JPA开发的代码和JDBC一样很烦人。
    
    JPA/Hibernate 关系?
    JPA是一种规范,而Hibernate是它的一种实现。除了Hibernate,还有EclipseLink(曾经的toplink),OpenJPA等可供选择,所以使用Jpa的一个好处是,可以更换实现而不必改动太多代码。
    
    什么是Spring Data?
    Spring Data是一个用于简化数据库访问,并支持云服务的开源框架。可以用Spring Data来简化项目的开发,就如Spring Framework对JDBC、ORM的支持一样,Spring Data会让数据的访问变得更加方便。
    
    什么是Spring Data JPA?
    spring Data JPA能干什么
    可以极大的简化JPA的写法,可以在几乎不用写实现的情况下,实现对数据的访问和操作。除了CRUD外,还包括如分页、排序等一些常用的功能。
        首先我们需要清楚的是Spring Data是一个开源框架,在这个框架中Spring Data JPA只是这个框架中的一个模块,所以名称才叫Spring Data JPA。如果单独使用JPA开发,你会发现这个代码量和使用JDBC开发一样有点烦人,所以Spring Data JPA的出现就是为了简化JPA的写法,让你只需要编写一个接口继承一个类就能实现CRUD操作了。
    Spring Boot JPA-Hibernate:
    步骤:
    (1)在pom.xml添加mysql,spring-data-jpa依赖;
    (2)在application.properties文件中配置mysql连接配置文件;
    (3)在application.properties文件中配置JPA配置信息;
    (4)编写测试例子;
    在pom.xml添加mysql,spring-data-jpa依赖
    <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
    </dependency>
    <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    
    在application.properties文件中配置mysql连接配置文件
    spring.datasource.url = jdbc:mysql://localhost:3306/springboot1
    spring.datasource.username = root
    spring.datasource.password = root
    spring.datasource.driverClassName = com.mysql.jdbc.Driver
    spring.datasource.max-active=20
    spring.datasource.max-idle=8
    spring.datasource.min-idle=8
    spring.datasource.initial-size=10
    
    ########################################################
    ### Java Persistence Api --  Spring jpau7684u914du7f6eu4fe1u606f.
    ########################################################
    # Specify the DBMS
    spring.jpa.database = MYSQL
    # Show or not log for each sql query
    spring.jpa.show-sql = true
    # Hibernate ddl auto (create, create-drop, update)
    spring.jpa.hibernate.ddl-auto = update
    # Naming strategy
    #[org.hibernate.cfg.ImprovedNamingStrategy  #org.hibernate.cfg.DefaultNamingStrategy]
    #命名策略:创建一个实体类的时候会自动创建表,表的命名是用的这个策略
    spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy
    # stripped before adding them to the entity manager)
    spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect
    
    
    编写测试例子
    (1)    创建实体类Demo,如果已经存在,可以忽略。
    (2)    创建jpa repository类操作持久化(CrudRepository)。
    (3)    创建service类。
    (4)    创建restful请求类。
    (5)    测试;

    Repository接口:
    Repository 接口是 Spring Data 的一个核心接口,它不提供任何方法,开发者需要在自己定义的接口中声明需要的方法 :
     public interface Repository<T, ID extends Serializable> { } 
    
    有这么几点需要强调下:
    1. Repository是一个空接口,即是一个标记接口;
    2. 若我们定义的接口继承了Repository,则该接口会被IOC容器识别为一个Repository Bean纳入到IOC容器中,进而可以在该接口中定义满足一定规范的方法。
    3. 实际上也可以通过@RepositoryDefinition,注解来替代继承Repository接口。
    4. 查询方法以find | read | get开头;
    5. 涉及查询条件时,条件的属性用条件关键字连接,要注意的是条件属性以首字母大写。
    6.使用@Query注解可以自定义JPQL语句实现更灵活的查询。
    
    CrudRepository 接口提供了最基本的对实体类的添删改查操作
     --T save(T entity);//保存单个实体   
      --Iterable<T> save(Iterable<? extends T> entities);//保存集合         
      --T findOne(ID id);//根据id查找实体          
      --boolean exists(ID id);//根据id判断实体是否存在          
      --Iterable<T> findAll();//查询所有实体,不用或慎用!          
      --long count();//查询实体数量          
      --void delete(ID id);//根据Id删除实体          
      --void delete(T entity);//删除一个实体   
      --void delete(Iterable<? extends T> entities);//删除一个实体的集合          
      --void deleteAll();//删除所有实体,不用或慎用!   
    
    PagingAndSortingRepository接口 : 该接口提供了分页与排序功能   
     --Iterable<T> findAll(Sort sort); //排序    
    --Page<T> findAll(Pageable pageable); //分页查询(含排序功能) 
    
    其它接口:
    JpaRepository:查找所有实体,排序、查找所有实体,执行缓存与数据库同步
    JpaSpecificationExecutor:不属于Repository体系,实现一组 JPA Criteria 查询相关的方法,封装  JPA Criteria 查询条件。通常使用匿名内部类的方式来创建该接口的对象。
    自定义 Repository:可以自己定义一个MyRepository接口。
  • 相关阅读:
    [Javascript] Broadcaster + Operator + Listener pattern -- 10. Define a Function to Set Common Behaviors in Operators
    [Java Spring] Aspect
    [Javascript] Broadcaster + Operator + Listener pattern -- 24. Design choice, ifElse or merge
    [Javascript] Broadcaster + Operator + Listener pattern -- 23. ifElse operator
    [Git] Revert to a old commit
    [Tools] Dendron
    [Java Spring] Spring Expression Language
    [Java Spring] @Profile
    [Java Spring] @Value & override properties by environment variables
    [Java Spring] Implementing Spring Security
  • 原文地址:https://www.cnblogs.com/yaowen/p/8560464.html
Copyright © 2011-2022 走看看