SpringBoot利用jpa连接MySQL数据库的方法

 更新时间:2022年10月20日 09:31:01   作者:LO嘉嘉VE  
这篇文章主要介绍了SpringBoot利用jpa连接MySQL数据库的方法,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

添加依赖

在pom文件中添加如下依赖

<!--添加Jpa依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <!--数据库链接驱动-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>

配置数据库连接 

在application.yml中添加数据库连接配置

# 应用服务 WEB 访问端口
server:
  port: 8080
# 应用名称
spring:
  application:
    name: HelloSpringBoot
  #数据库配置连接
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/hello_jpa?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
    username: root
    password: "123456"
    driver-class-name: com.mysql.cj.jdbc.Driver
  jpa:
    show-sql: true

配置上数据库的连接地址和账号密码

url: jdbc:mysql://127.0.0.1:3306/hello_jpa??useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai

数据库连接地址

127.0.0.1表示本地

3306数据库端口号

hello_jpa数据库名称

useUnicode=true&characterEncoding=utf-8配置数据库连接使用UTF8编码

serverTimezone=Asia/Shanghai配置时间为北京时间

username 配置数据库名称 root

password 配置数据库密码 123456

driver-class-name 配置mysql的驱动 com.mysql.cj.jdbc.Driver

show-sql配置控制台是否打印访问数据库时的sql语句,配置为true,显示sql语句,方便调试。

启动项目,看到如下信息,表示数据库连接成功,如果显示错误,请查验是否数据库连接信息有错误。

创建测试数据库表

CREATE TABLE `jpa_user`  (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '自增主键',
  `username` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '用户名称',
  `age` tinyint(4) NULL DEFAULT NULL COMMENT '年龄',
  `gender` tinyint(4) NULL DEFAULT NULL COMMENT '性别0女 1男',
  `phone` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '手机号',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

Java代码部分

建实体类和Repository

jpa_user表对应实体类User

//引入lombok的getset注解,也可以不引入,自己写下面字段的对应getset方法
@Getter
@Setter
//注解此类为实体类
@Entity
//关联数据库表的名称
@Table(name = "jpa_user")
public class User {
 
    //声明属性为主键
    @Id
    //指定主键生成策略
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    // @Column注解,设置属性关联的数据库表字段
    // 注意:如果属性名和表字段名相同,可以不设置,比如这个实体类对应的所有字段就都是与数据库表字段相同的,都可以不设置Column注解
    @Column(name = "id")
    private Long id;
 
    @Column(name = "username")
    private String username;
 
    @Column(name = "age")
    private Integer age;
 
    @Column(name = "gender")
    private Integer gender;
 
    @Column(name = "phone")
    private String phone;
 
    //驼峰命名法和数据库中的下划线字段是对应的
    @Column(name = "access_card_number")
    private String accessCardNumber;
 
}

创建UserRepository,数据库操作类

public interface UserRepository extends JpaRepository<User, Long> {
}

是的,这个接口没有定义方法,只要继承JpaRepository就可以,<User, Long>分别对应的要连接的实体类和主键类型。

JpaRepository内置好了基本的增删查改接口及排序和分页功能。

做个简单的代码测试

往数据库中插入数据

        //insert into jpa_user (access_card_number, age, gender, phone, username) values (?, ?, ?, ?, ?)
        User user = new User();
        user.setUsername("test");
        user.setPhone("13112345678");
        user.setAge(18);
        user.setGender(0);
        user.setAccessCardNumber("ic_001");
        userRepository.save(user);

根据主键id查找数据

//select * from jpa_user user where user.id=?
        User user = userRepository.findById(id).orElse(null);

修改id为1的数据

//update jpa_user set access_card_number=?, age=?, gender=?, phone=?, username=? where id=?
        User user = userRepository.findById(1L).orElse(null);
        user.setPhone("13212345678");
        userRepository.save(user);

删除id为1的数据

//update jpa_user set access_card_number=?, age=?, gender=?, phone=?, username=? where id=?
        User user = userRepository.findById(1L).orElse(null);
        user.setPhone("13212345678");
        userRepository.save(user);

where语句与查找数据

在UserRepository中定义一个方法

//select * from jpa_user user where (user.age between ? and ?) and user.gender=?
 
List<User> findByAgeBetweenAndGender(int minAge, int maxAge, int gender);

在repository中我们可以自定义查找条件的方法

findBy前缀为查找实体数据,countBy前缀表示查找实体数量,deleteBy前缀为删除数据

这三种后面跟随的都是查找条件,多条件用and或or连接

比如上面的例子就是搜索(age between minAge and maxAge) and gender = gender

搜索条件支持定向查找,模糊查找,比较查找等等。

测试代码地址:HelloSpringBoot: SpringBoot测试项目

到此这篇关于SpringBoot利用jpa连接MySQL数据库的文章就介绍到这了,更多相关SpringBoot连接MySQL内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 基于Java并发容器ConcurrentHashMap#put方法解析

    基于Java并发容器ConcurrentHashMap#put方法解析

    下面小编就为大家带来一篇基于Java并发容器ConcurrentHashMap#put方法解析。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • Java Swing中的文本框(JTextField)与文本区(JTextArea)使用实例

    Java Swing中的文本框(JTextField)与文本区(JTextArea)使用实例

    这篇文章主要介绍了Java Swing中的文本框(JTextField)与文本区(JTextArea)使用实例,Swing是一个用于开发Java应用程序用户界面的开发工具包,需要的朋友可以参考下
    2014-10-10
  • Springboot重写addInterceptors()方法配置拦截器实例

    Springboot重写addInterceptors()方法配置拦截器实例

    这篇文章主要介绍了Springboot重写addInterceptors()方法配置拦截器实例,spring boot抛弃了复杂的xml配置,我们可以自定义配置类(标注@Configuration注解的类)来实现WebMvcConfigurer接口,并重写addInterceptors()方法来配置拦截器,需要的朋友可以参考下
    2023-09-09
  • Java外观模式解读,让你的代码优雅又高效

    Java外观模式解读,让你的代码优雅又高效

    外观模式(Facade Pattern)是一种常用的结构型设计模式,它为复杂的子系统提供一个简单的接口,隐藏复杂的实现细节,本文就来讲讲它是如何简化代码,提高可维护性的
    2023-05-05
  • SpringBoot LiteFlow引擎框架使用原理解析

    SpringBoot LiteFlow引擎框架使用原理解析

    LiteFlow是一个轻量且强大的国产规则引擎框架,可用于复杂的组件化业务的编排领域,本文给大家介绍SpringBoot LiteFlow引擎框架的相关操作,感兴趣的朋友跟随小编一起看看吧
    2024-03-03
  • Java实现多线程断点下载

    Java实现多线程断点下载

    这篇文章主要为大家详细介绍了Java实现多线程断点下载的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • 带你一文深入认识Java String类

    带你一文深入认识Java String类

    这篇文章主要介绍了带你一文深入认识Java String类,String 类在Java中是很常用的类,很重要的类,在后续的学习中经常会用到,是后续学习的基础, 文章围绕主题展开更多详细内容,需要的小伙伴可以参考一下,希望对你的学习有所帮助
    2022-06-06
  • Java下载文件中文文件名乱码的解决方案(文件名包含很多%)

    Java下载文件中文文件名乱码的解决方案(文件名包含很多%)

    Java下载文件时,文件名中文乱码问题通常是由于编码不正确导致的,使用`URLEncoder.encode(filepath, "UTF-8")`可以解决在提示下载框中正确显示汉字文件名的问题,但在选择直接打开时,文件名会变成乱码,解决这个问题的方法
    2025-02-02
  • Java比较问题详细分析

    Java比较问题详细分析

    本篇文章主要给大家讲解了Java中比较问题的相关知识,一起参考学习下吧。
    2017-12-12
  • Java 超详细讲解数据结构中的堆的应用

    Java 超详细讲解数据结构中的堆的应用

    堆首先是一个完全二叉树,堆分为小根堆和大根堆。小根堆,所有结点的左右子节点都不小于根节点;大根堆,所有结点的左右子节点都不大于根节点。优先级队列(priorityQueue)底层就是一个小根堆
    2022-04-04

最新评论