千家信息网

SpringBoot2如何实现集成JPA持久层框架、简化数据库操作

发表于:2025-02-23 作者:千家信息网编辑
千家信息网最后更新 2025年02月23日,这篇文章主要为大家展示了"SpringBoot2如何实现集成JPA持久层框架、简化数据库操作",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"SpringBo
千家信息网最后更新 2025年02月23日SpringBoot2如何实现集成JPA持久层框架、简化数据库操作

这篇文章主要为大家展示了"SpringBoot2如何实现集成JPA持久层框架、简化数据库操作",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"SpringBoot2如何实现集成JPA持久层框架、简化数据库操作"这篇文章吧。

一、JAP框架简介

JPA(Java Persistence API)意即Java持久化API,是Sun官方在JDK5.0后提出的Java持久化规范。主要是为了简化持久层开发以及整合ORM技术,结束Hibernate、TopLink、JDO等ORM框架各自为营的局面。JPA是在吸收现有ORM框架的基础上发展而来,易于使用,伸缩性强。

二、与SpringBoot2整合

1、核心依赖

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

2、配置文件

spring:  application:    name: node09-boot-jpa  datasource:    url: jdbc:mysql://localhost:3306/data_jpa?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true    username: root    password: root    driver-class-name: com.mysql.jdbc.Driver  jpa:    hibernate:      ddl-auto: update    show-sql: true

ddl-auto几种配置说明
1)create
每次加载hibernate时都删除上一次的生成的表,然后根据bean类重新来生成新表,容易导致数据丢失,(建议首次创建时使用)。
2)create-drop
每次加载hibernate时根据bean类生成表,但是sessionFactory一关闭,表就自动删除。
3)update
第一次加载hibernate时根据bean类会自动建立起表的结构,以后加载hibernate时根据bean类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。
4)validate
每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值。

3、实体类对象

就是根据这个对象生成的表结构。

@Table(name = "t_user")@Entitypublic class User {    @Id    @GeneratedValue    private Integer id;    @Column    private String name;    @Column    private Integer age;    // 省略 GET SET}

4、JPA框架的用法

定义对象的操作的接口,继承JpaRepository核心接口。

import com.boot.jpa.entity.User;import org.springframework.data.jpa.repository.JpaRepository;import org.springframework.data.jpa.repository.Query;import org.springframework.data.repository.query.Param;import org.springframework.stereotype.Repository;@Repositorypublic interface UserRepository extends JpaRepository {    // 但条件查询    User findByAge(Integer age);    // 多条件查询    User findByNameAndAge(String name, Integer age);    // 自定义查询    @Query("from User u where u.name=:name")    User findSql(@Param("name") String name);}

5、封装一个服务层逻辑

import com.boot.jpa.entity.User;import com.boot.jpa.repository.UserRepository;import org.springframework.stereotype.Service;import javax.annotation.Resource;@Servicepublic class UserService {    @Resource    private UserRepository userRepository ;    // 保存    public void addUser (User user){        userRepository.save(user) ;    }    // 根据年龄查询    public User findByAge (Integer age){        return userRepository.findByAge(age) ;    }    // 多条件查询    public User findByNameAndAge (String name, Integer age){        return userRepository.findByNameAndAge(name,age) ;    }    // 自定义SQL查询    public User findSql (String name){        return userRepository.findSql(name) ;    }    // 根据ID修改    public void update (User user){        userRepository.save(user) ;    }    //根据id删除一条数据    public void deleteStudentById(Integer id){        userRepository.deleteById(id);    }}

三、测试代码块

import com.boot.jpa.JpaApplication;import com.boot.jpa.entity.User;import com.boot.jpa.service.UserService;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;import javax.annotation.Resource;@RunWith(SpringJUnit4ClassRunner.class)@SpringBootTest(classes = JpaApplication.class)public class UserJpaTest {    @Resource    private UserService userService ;    @Test    public void addUser (){        User user = new User() ;        user.setName("知了一笑");        user.setAge(22);        userService.addUser(user);        User user1 = new User() ;        user1.setName("cicada");        user1.setAge(23);        userService.addUser(user1);    }    @Test    public void findByAge (){        Integer age = 22 ;        // User{id=3, name='知了一笑', age=22}        System.out.println(userService.findByAge(age));    }    @Test    public void findByNameAndAge (){        System.out.println(userService.findByNameAndAge("cicada",23));    }    @Test    public void findSql (){        // User{id=4, name='cicada', age=23}        System.out.println(userService.findSql("cicada"));    }    @Test    public void update (){        User user = new User() ;        // 如果这个主键不存在,会以主键自增的方式新增入库        user.setId(3);        user.setName("哈哈一笑");        user.setAge(25);        userService.update(user) ;    }    @Test    public void deleteStudentById (){        userService.deleteStudentById(5) ;    }}

以上是"SpringBoot2如何实现集成JPA持久层框架、简化数据库操作"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

数据 框架 查询 数据库 结构 生成 内容 对象 条件 篇文章 接口 核心 学习 帮助 整合 配置 代码 伸缩性 基础 官方 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 多方联动齐织网络安全网 华为服务器生产线在河南哪里 监控系统管理服务器的作用 数据库创建的用户能登录数据库吗 安士能网络安全锁 db2数据库单引号如何存库 远程教学系统软件开发 黑龙江前端软件开发 病理传输软件开发文档范例 软件开发与测试比重 网络安全教育800字演讲稿 服务器上用的硬盘是什么硬盘 如何快速检测服务器断开 江苏斯点网络技术有限公司 oracle服务器登陆 linux服务器管理与应用 做互联网物业需要科技公司吗 腾讯云提供服务器安全吗 软件开发费是否属于研发费 什么数据库支持第一作者检索 http服务器框架 药智数据基本药物目录查询数据库 南大通用数据库运营原理 数据库和数字图书馆的异同 mui选择器获取数据库动态 中国网络安全大会9月22 软件开发公司产品与服务 开展经常性的网络安全宣传 浦东新区软件开发技术服务公司 数据库建设红头文件
0