JPA、Hibernate、Spring data jpa之间的关系,终于明白了

什么么是JPA?

全称Java Persistence API,可以通过注解或者XML描述【对象-关系表】之间的映射关系,并将实体对象持久化到数据库中。

为我们提供了:

1)ORM映射元数据:JPA支持XML和注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象持久化到数据库表中;

如:@Entity、@Table、@Column、@Transient等注解。

 2)JPA 的API:用来操作实体对象,执行CRUD操作,框架在后台替我们完成所有的事情,开发者从繁琐的JDBC和SQL代码中解脱出来。

如:entityManager.merge(T t);

 3)JPQL查询语言:通过面向对象而非面向数据库的查询语言查询数据,避免程序的SQL语句紧密耦合。

如:from Student s where s.name = ?

但是:

JPA仅仅是一种规范,也就是说JPA仅仅定义了一些接口,而接口是需要实现才能工作的。所以底层需要某种实现,而Hibernate就是实现了JPA接口的ORM框架。

Hibernate

也就是说:

JPA是一套ORM规范,Hibernate实现了JPA规范!如图:

什么是spring data jpa?

spirng data jpa是spring提供的一套简化JPA开发的框架,按照约定好的【方法命名规则】写dao层接口,就可以在不写接口实现的情况下,实现对数据库的访问和操作。同时提供了很多除了CRUD之外的功能,如分页、排序、复杂查询等等。

Spring Data JPA 可以理解为 JPA 规范的再次封装抽象,底层还是使用了 Hibernate 的 JPA 技术实现。如图:

接口约定命名规则:

实例:

创建数据库: 

在test数据库中创建user表

-- ----------------------------
-- Table structure for `user`
-- ----------------------------
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(50) DEFAULT NULL,
  `password` varchar(50) DEFAULT NULL,
  `name` varchar(50) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES ('1', 'zhangsan', '123', '张三');
INSERT INTO `user` VALUES ('2', 'lisi', '123', '李四');

 

 添加Spring Data JPA的起步依赖

<!-- springBoot JPA的起步依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

 

 添加数据库驱动依赖

<!-- MySQL连接驱动 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

 

 在application.properties中配置数据库和jpa的相关属性

#DB Configuration:
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=root
​
#JPA Configuration:
spring.jpa.database=MySQL
spring.jpa.show-sql=true
spring.jpa.generate-ddl=true
spring.jpa.hibernate.ddl-auto=update
spring.jpa.hibernate.naming_strategy=org.hibernate.cfg.ImprovedNamingStrategy

 

 创建实体配置实体

@Entity
public class User {
    // 主键
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    // 用户名
    private String username;
    // 密码
    private String password;
    // 姓名
    private String name;
 
    //此处省略setter和getter方法... ...
}

 

 编写UserRepository

public interface UserRepository extends JpaRepository<User,Long>{
    public List<User> findAll();
}

 编写测试类

@RunWith(SpringRunner.class)
@SpringBootTest(classes=MySpringBootApplication.class)
public class JpaTest {
​
    @Autowired
    private UserRepository userRepository;
​
    @Test
    public void test(){
        List<User> users = userRepository.findAll();
        System.out.println(users);
    }
​
}

 

 控制台打印信息

 

注意:如果是jdk9,执行报错如下:

 

原因:jdk缺少相应的jar

解决方案:手动导入对应的maven坐标,如下:

<!--jdk9需要导入如下坐标-->
<dependency>
    <groupId>javax.xml.bind</groupId>
    <artifactId>jaxb-api</artifactId>
    <version>2.3.0</version>
</dependency>

 

第二种整合:

springboot集成spring data jpa只需两步:

第一步:导入maven坐标

第二步:yml配置文件中配置jpa信息

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hibernate、MyBatis和Spring Data JPA都是Java持久化框架,但它们各自有不同的优缺点。 Hibernate是一个全自动ORM框架,它可以将Java对象映射到数据库表中。Hibernate具有以下优点: - 简化了数据库操作,使开发变得更加容易和快捷。 - Hibernate具有强大的缓存机制,可以提高应用程序的性能。 - 支持延迟加载和预取,可以优化查询性能。 - Hibernate提供了丰富的映射关系和查询功能,可以满足复杂业务场景的需求。 但是,Hibernate也存在一些缺点: - Hibernate自动生成的SQL语句可能不够优化,导致性能问题。 - Hibernate的学习曲线比较陡峭,需要掌握复杂的映射关系和查询语言。 - Hibernate的配置比较复杂,需要花费一定的时间和精力。 MyBatis是一个半自动化ORM框架,它将SQL语句与Java代码分离。MyBatis具有以下优点: - MyBatis使用简单,易于学习和使用。 - MyBatis具有良好的灵活性,可以自由控制SQL语句的生成。 - MyBatis支持较好的批量处理和动态SQL,可以提高性能。 但是,MyBatis也存在一些缺点: - MyBatis需要手写SQL语句,对于复杂的查询可能会比较麻烦。 - MyBatis对于多表关联的查询支持相对较弱,需要手动编写复杂的SQL语句。 - MyBatis的错误提示不够友好,需要花费一定的时间和精力进行排查。 Spring Data JPASpring Data家族中的一个成员,它是一个全自动化ORM框架,使用JPA规范。Spring Data JPA具有以下优点: - Spring Data JPA提供了大量的自动化特性,可以大幅度减少开发时间。 - Spring Data JPA支持多种数据库,可以灵活地切换数据库。 - Spring Data JPA提供了良好的错误提示和调试信息,方便排查问题。 但是,Spring Data JPA也存在一些缺点: - Spring Data JPA对于复杂查询的支持相对较弱,需要手写SQL语句。 - Spring Data JPA的性能可能存在一定的问题,需要合理配置和优化。 - Spring Data JPA依赖于JPA规范,可能对于一些特殊需求不太适用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值