springboot+mybatis通过实体类自动生成数据库表的方法

下面我将详细讲解“springboot+mybatis通过实体类自动生成数据库表的方法”的完整攻略,其中会包含两个示例。

1. 引入依赖

首先,在工程的pom.xml文件中引入如下依赖:

<!-- Spring Boot 依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
    <version>2.4.3</version>
</dependency>

<!-- Spring Boot MyBatis 依赖 -->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.4</version>
</dependency>

<!-- MySQL 驱动依赖 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.23</version>
</dependency>

2. 配置 MySQL 数据库

application.properties文件中配置 MySQL 数据库连接信息:

# 数据库配置
spring.datasource.url=jdbc:mysql://localhost:3306/db_example
spring.datasource.username=username
spring.datasource.password=password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

3. 编写实体类

编写实体类User.java,用于生成对应的数据库表:

public class User {
    private Long id;
    private String name;
    private Integer age;

    // Getter and Setter 方法省略
}

4. 编写 MyBatis 映射文件

UserMapper.xml文件中编写 SQL 映射语句,用于生成对应的数据库表:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.example.mapper.UserMapper">

    <resultMap id="BaseResultMap" type="com.example.entity.User">
        <id column="id" property="id"/>
        <result column="name" property="name"/>
        <result column="age" property="age"/>
    </resultMap>

    <sql id="Base_Column_List">
        id, name, age
    </sql>

    <insert id="insert" parameterType="com.example.entity.User">
        insert into user
        (<include refid="Base_Column_List"/>)
        values
        (#{id}, #{name}, #{age})
    </insert>

    <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap">
        select
        <include refid="Base_Column_List"/>
        from user
        where id =#{id}
    </select>

</mapper>

5. 启动项目

启动 Spring Boot 项目,MyBatis 在启动时会自动扫描com.example.entity包下的所有实体类,自动生成对应的数据库表。

示例一:新增数据

在控制器UserController.java中新增一个用户:

@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserMapper userMapper;

    @PostMapping("/add")
    public String addUser() {
        User user = new User();
        user.setId(1L);
        user.setName("Tom");
        user.setAge(18);
        userMapper.insert(user);
        return "添加成功";
    }
}

然后发送一个 POST 请求:http://localhost:8080/user/add,就可以在数据库中查看到添加的数据。

示例二:查询数据

在控制器UserController.java中查询一个用户:

@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserMapper userMapper;

    @GetMapping("/{id}")
    public User getUserById(@PathVariable Long id) {
        return userMapper.selectByPrimaryKey(id);
    }
}

然后发送一个 GET 请求:http://localhost:8080/user/1,就可以查询到数据库中 ID 为 1 的用户信息。

至此,就可以通过实体类自动生成数据库表了,希望对你有所帮助。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:springboot+mybatis通过实体类自动生成数据库表的方法 - Python技术站

(1)
上一篇 2023年5月20日
下一篇 2023年5月20日

相关文章

  • java操作oracle数据库示例

    以下是 Java 操作 Oracle 数据库的完整攻略: 环境 在开始之前,需要确定自己的开发环境中是否已经安装好 JDK 和 Oracle 数据库,并且已经配置好了相应的环境变量。如果没有,请先安装和配置好相应的软件和环境。 另外,如果需要在Java中操作Oracle数据库,还需要下载安装 ojdbc 驱动程序,将其放置于项目根目录下或指定的lib目录下。…

    Java 2023年5月19日
    00
  • Java超详细分析抽象类和接口的使用

    Java超详细分析抽象类和接口的使用 什么是抽象类? 抽象类是一个不能被实例化的类,它的作用是为子类提供一组公共的方法或属性,而不实现它们的具体实现。因为抽象类无法被实例化,所以只有它的子类可以被实例化。抽象类是通过使用 abstract 关键字定义的。 抽象类的定义 抽象类定义的方式是通过使用 abstract 关键字: public abstract c…

    Java 2023年5月26日
    00
  • Spring Boot深入学习数据访问之Spring Data JPA与Hibernate的应用

    Spring Boot深入学习数据访问之Spring Data JPA与Hibernate的应用 什么是Spring Data JPA? Spring Data JPA 是 Spring Data 一个子数据访问项目,该项目基于Spring框架为开发人员提供了一个基于JPA的工具包,方便开发人员使用JPA来访问数据库。 Spring Boot 中使用Spri…

    Java 2023年5月19日
    00
  • Java多线程Callable接口实现代码示例

    下面是Java多线程Callable接口实现的完整攻略步骤: 1.什么是Callable接口 Callable和Runnable类似,都是用来创建线程的接口,但是Callable的call()方法有返回值,并且可以抛出异常。 public interface Callable<V> { V call() throws Exception; } 2…

    Java 2023年5月19日
    00
  • SpringBoot搭建全局异常拦截

    一、概述 在使用Spring Boot开发Web应用的过程中,我们经常会遇到程序抛出异常的情况。如何优雅地处理这些异常,返回友好的错误信息给客户端,是很重要的一件事情。Spring Boot提供了全局异常处理机制,可以方便地实现统一的异常处理逻辑,减少代码重复,提高开发效率。 本文将介绍如何使用Spring Boot自带的全局异常处理机制,搭建一个通用的全局…

    Java 2023年5月27日
    00
  • 教你如何写springboot接口

    教你如何写Spring Boot接口攻略 1. 确定项目需求和数据库设计 在编写Spring Boot接口前,需要先明确项目需求和数据库设计,包括接口需要实现哪些功能,数据表的关系等。这样才能确保编写出的接口满足项目需求。同时,我们还需要确定使用的数据库类型和数据库连接方式。 2. 创建Spring Boot项目 接下来我们需要使用Spring Initia…

    Java 2023年5月19日
    00
  • IDEA连接Mysql数据库的详细图文教程

    下面是“IDEA连接MySQL数据库的详细图文教程”的完整攻略,包含两条示例。 准备工作 首先需要准备好以下工具和环境:- IntelliJ IDEA(版本最好是Community或Ultimate,均支持插件安装)- MySQL数据库- MySQL JDBC驱动程序(可以从mysql官网下载) 安装MySQL JDBC驱动程序 下载MySQL JDBC驱动…

    Java 2023年5月20日
    00
  • 剑指Offer之Java算法习题精讲数组与字符串题

    以下是“剑指Offer之Java算法习题精讲数组与字符串题”的完整攻略。 1. 确定题目类型 在学习算法习题时,首先要确定题目类型,以便可以快速地想出解题思路。本篇攻略的主要题目类型为数组与字符串。在处理数组与字符串问题时,可以考虑使用双指针、哈希表和动态规划等常用的技巧。 2. 学习题目解法思路 在确定了题目类型之后,使用双指针、哈希表和动态规划等技巧,根…

    Java 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部