iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >SpringBoot利用jpa连接MySQL数据库的方法
  • 788
分享到

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

SpringBoot连接MySQLSpringBoot jpa连接MySQL数据库 2022-11-13 18:11:22 788人浏览 八月长安
摘要

目录添加依赖配置数据库连接 创建测试数据库表Java代码部分做个简单的代码测试where语句与查找数据添加依赖 在pom文件中添加如下依赖 <!--添加Jp

添加依赖

在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内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: SpringBoot利用jpa连接MySQL数据库的方法

本文链接: https://www.lsjlt.com/news/169742.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SpringBoot利用jpa连接MySQL数据库的方法
    目录添加依赖配置数据库连接 创建测试数据库表Java代码部分做个简单的代码测试where语句与查找数据添加依赖 在pom文件中添加如下依赖 <!--添加Jp...
    99+
    2022-11-13
    SpringBoot连接MySQL SpringBoot jpa连接MySQL数据库
  • SpringBoot连接MYSQL数据库并使用JPA进行操作
    今天给大家介绍一下如何SpringBoot中连接Mysql数据库,并使用JPA进行数据库的相关操作。步骤一:在pom.xml文件中添加MYSQl和JPA的相关Jar包依赖,具体添加位置在dependencies中,具体添加的内容如下所示。&...
    99+
    2023-05-31
    jpa mysql spring
  • Mysql的数据库连接---SpringBoot
    1.原生态连接 ①:准备工作:引入mysql依赖:                  mysql            mysql-connector-java            5.1.6         ②:书写DBUtil工具...
    99+
    2023-09-03
    数据库 mysql spring boot
  • springboot用jedis连接Redis数据库的方法
    本篇内容介绍了“springboot用jedis连接Redis数据库的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!springboot...
    99+
    2023-06-20
  • mysql连接数据库的方法
    小编给大家分享一下mysql连接数据库的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!连接方法:1、打开DOS窗口,进入目录...
    99+
    2022-10-18
  • Spring\SpringBoot配置连接数据库的方法
    Spring配置连接数据库 设置jdbc.properties jdbc.driverClassName=com.mysql.jdbc.Driver jdbc.url=jdbc:...
    99+
    2022-11-12
  • vc 连接mysql数据库的方法
    这篇文章给大家分享的是有关vc 连接mysql数据库的方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。vc连接mysql数据库的方法:首先打开VC6;然后在中间列表框中添加本地...
    99+
    2022-10-18
  • .net连接mysql数据库的方法
    小编给大家分享一下.net连接mysql数据库的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!net连接mysql数据库的方...
    99+
    2022-10-18
  • Nacicat连接MySQL数据库的方法
    Nacicat连接MySQL数据库的方法?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!1、安装好MySQL和Navicat...
    99+
    2022-10-18
  • C#连接Mysql数据库的方法
    C#连接Mysql数据库的方法?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!本文讲的是C#连接Mysql数据库,下文附有详...
    99+
    2022-10-18
  • Android连接MySQL数据库的方法
    由于之前那篇文章是在大学期间好多东西都不太懂的时候写的,放到现在再来看总感觉到处都是问题(或者说已经看不懂啦)。但是看到每天上涨的那点阅读量,想了想还是把这个再用相对正常的方式再重写一遍吧。 为了省事本项目的服务端采用SpringBoot ...
    99+
    2023-10-07
    mysql 数据库 android
  • php7连接mysql数据库的方法
    这篇文章主要为大家展示了php7连接mysql数据库的方法,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“php7连接mysql数据库的方法”这篇文章吧。php有什么用php是一个嵌套的缩写名称,指...
    99+
    2023-06-06
  • Springboot2.0配置JPA多数据源连接两个mysql数据库方式
    目录1. 目录结构及配置2. 配置文件3. DataSourceConfigurer类4. 主数据源配置5. 从数据源配置6.User实体类模板7.dao层模板8.service模板...
    99+
    2022-11-12
  • ASP连接MySQL数据库的方法(转)
    ASP连接MySQL数据库的方法(转)[@more@]<% '测试读取MySql数据库的内容strconnection="driver={mysql odbc 3.51 driver};database=w...
    99+
    2022-10-18
  • mysql登录数据库连接的方法
    这篇文章主要介绍了mysql登录数据库连接的方法,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。mysql登录数据库连接的方法:首先打开Workb...
    99+
    2022-10-18
  • SpringBoot 是怎样连接 MySql 数据库的
    Spring Boot 是一款流行的 Java 开发框架,它可以轻松地连接各种类型的数据库,包括关系型数据库和非关系型数据库。本文将介绍 Spring Boot 是如何连接数据库的,包括其原理和代码示例。 一、Spring Boot 连接...
    99+
    2023-08-18
    数据库 spring boot mysql
  • 详解springboot 使用c3p0数据库连接池的方法
    使用springboot开发时,默认使用内置的tomcat数据库连接池,经常碰到这种情况:运行时间一长,数据库连接中断了。所以使用c3p0连接池吧。引入的maven依赖:<dependency> <groupId>...
    99+
    2023-05-31
    spring boot c3p0
  • IDEA连接MySQL数据库的四种方法
    首先右击此电脑点击管理,进入页面  再服务栏确保MySQL是正常运行状态 打开IDEA, 左边栏选择Maven Archetype,新建一个名为javaweb的新工程 进行如图编辑完成新建  在Main包下新建一个java包,右击jav...
    99+
    2023-09-22
    mybatis
  • win7上python2.7连接mysql数据库的方法
    一:安装MySQL-python驱动 pip install mysql 二:连接到MySQL服务器的test数据库 #!/usr/bin/python # -*- coding: UTF...
    99+
    2022-06-04
    数据库 方法 mysql
  • django2.2版本连接mysql数据库的方法
    一、运行项目报错信息如下: File "/home/pyvip/.virtualenvs/myblog/lib/python3.6/site-packages/django/db/backends/my...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作