iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Java中如何使用MyBatis-Plus操作数据库
  • 617
分享到

Java中如何使用MyBatis-Plus操作数据库

2023-06-29 02:06:11 617人浏览 八月长安
摘要

这篇文章主要介绍Java中如何使用mybatis-Plus操作数据库,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!MyBatis-PlusMyBatis-Plus (opens new window)(简称 MP)是

这篇文章主要介绍Java中如何使用mybatis-Plus操作数据库,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

MyBatis-Plus

MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

MyBatis可以直接在xml中通过sql语句操作数据库,很灵活。但其操作都要通过SQL语句进行,就必须写大量的xml文件,很麻烦。mybatis-plus就很好的解决了这个问题。

官网

MyBatis-Plus 官方文档

使用

        这里我用的数据库是mysql8,新建test数据库,并创建user表

Java中如何使用MyBatis-Plus操作数据库

Java中如何使用MyBatis-Plus操作数据库

     建表语句

SET NAMES utf8mb4;SET FOREIGN_KEY_CHECKS = 0; -- ------------------------------ Table structure for user-- ----------------------------DROP TABLE IF EXISTS `user`;CREATE TABLE `user`  (  `id` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '主键',  `name` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '姓名',  `age` int(0) NULL DEFAULT NULL COMMENT '年龄',  `address` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '地址',  PRIMARY KEY (`id`) USING BTREE) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic; SET FOREIGN_KEY_CHECKS = 1;

  引入依赖

        这里我用的数据库是Mysql8

     <parent>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-parent</artifactId>        <version>2.6.3</version>        <relativePath/>    </parent>     <dependencies>        <dependency>            <groupId>org.projectlombok</groupId>            <artifactId>lombok</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-devtools</artifactId>            <scope>runtime</scope>            <optional>true</optional>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-test</artifactId>            <scope>test</scope>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-test</artifactId>        </dependency>        <dependency>            <groupId>junit</groupId>            <artifactId>junit</artifactId>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-test</artifactId>        </dependency>        <dependency>            <groupId>com.baomidou</groupId>            <artifactId>mybatis-plus-boot-starter</artifactId>            <version>3.5.1</version>        </dependency>        <!--Druid连接池-->        <dependency>            <groupId>com.alibaba</groupId>            <artifactId>druid-spring-boot-starter</artifactId>            <version>1.1.9</version>        </dependency>        <dependency>            <groupId>mysql</groupId>            <artifactId>mysql-connector-java</artifactId>            <version>8.0.25</version>        </dependency>    </dependencies>

分别创建application.yml及application-dev.yml文件

 application.yml

# Spring配置spring:  # 环境设置  profiles:    active: dev  # 模板引擎  thymeleaf:    mode: html    encoding: utf-8    # 禁用缓存    cache: false  # 服务模块  devtools:    restart:      # 热部署开关      enabled: true

application-dev.yml

# 开发环境配置server:  # 服务器Http端口,默认为80  port: 8081 spring:  datasource:    type: com.alibaba.druid.pool.DruidDataSource    driver-class-name: com.mysql.cj.jdbc.Driver    druid:      url: jdbc:mysql://localhost:3307/test?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8      username: root      passWord: 123456      initial-size: 5      min-idle: 10      max-active: 20      max-wait: 60000      time-between-eviction-runs-millis: 60000      min-evictable-idle-time-millis: 300000      validation-query: select 'x'      test-while-idle: true      test-on-borrow: false      test-on-return: false      pool-prepared-statements: true      max-open-prepared-statements: 50      max-pool-prepared-statement-per-connection-size: 20

编写实体类User.java,这里用到lombok

@Datapublic class User {    private String id;    private String name;    private Integer age;    private String address;}

创建mapper文件夹,并编写 Mapper 类 UserMapper.java

public interface UserMapper extends BaseMapper<User> { }

Spring Boot 启动类中添加 @MapperScan 注解,扫描 Mapper 文件夹:

@SpringBootApplication@MapperScan("com.mybatisplus.mapper")public class MainApplication {    public static void main(String[] args)    {        SpringApplication.run(MainApplication.class, args);    }}

添加测试类,进行功能测试:

测试数据插入数据库

    @Autowired    private UserMapper userMapper;     @Test    public void testInsert() {        System.out.println(("----- insert method test ------"));        User user = new User();        // 自动生成主键,例如550E8400-E29B-11D4-A716-446655440000        String id = UUID.randomUUID().toString();        String replaceAll = id.replaceAll("-", "");        //550E8400E29B11D4A716446655440000        user.setId(replaceAll);        user.setName("张三");        user.setAge(21);        user.setAddress("北京市海淀区");        int insert = userMapper.insert(user);        if(insert>0){            System.out.println("插入成功:"+user);        }else{            System.out.println("插入失败!");        }    }

Java中如何使用MyBatis-Plus操作数据库

Java中如何使用MyBatis-Plus操作数据库

 测试查询所有

    @Autowired    private UserMapper userMapper;            @Test    public void testSelect() {        System.out.println(("----- selectAll method test ------"));        List<User> userList = userMapper.selectList(null);        userList.forEach(System.out::println);    }

Java中如何使用MyBatis-Plus操作数据库

 测试删除数据

        删除姓名等于“张三”的记录

    @Autowired    private UserMapper userMapper;        @Test    public void testDelete() {        System.out.println(("----- delete method test ------"));        LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();        User user = new User();        user.setName("张三");        wrapper.eq(User::getName, user.getName());        int delete = userMapper.delete(wrapper);        if(delete>0){            System.out.println("删除成功:"+user);        }else{            System.out.println("删除失败!");        }    }

Java中如何使用MyBatis-Plus操作数据库

 测试修改数据

 修改前先执行下插入

Java中如何使用MyBatis-Plus操作数据库

        修改还可以用userMapper.updateById(T entity)方法来修改,传入一个实体类

    @Autowired    private UserMapper userMapper;        @Test    public void testUpdate() {        System.out.println(("----- update method test ------"));        LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();        User user = new User();        user.setName("张三");        wrapper.eq(User::getName, user.getName());        User userNew = new User();        userNew.setName("李四");        int update = userMapper.update(userNew, wrapper);        if(update>0){            System.out.println("修改成功:"+user);        }else{            System.out.println("修改失败!");        }    }

Java中如何使用MyBatis-Plus操作数据库

Java中如何使用MyBatis-Plus操作数据库

以上是“Java中如何使用MyBatis-Plus操作数据库”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: Java中如何使用MyBatis-Plus操作数据库

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

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

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

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

下载Word文档
猜你喜欢
  • c语言怎么读入字符串中的数字符号
    使用 atoi() 函数可以将字符串中的数字转换为整数,具体步骤如下:包含 stdlib.h 头文件。使用 atoi() 函数,用法为:int num = atoi(str);其中 st...
    99+
    2024-05-14
    c语言
  • c语言怎么查找文件中的数据
    c 语言中查找文件中的数据步骤:打开文件;定位到数据点;读取数据;关闭文件。 如何使用 C 语言查找文件中的数据 在 C 语言中,可以通过以下步骤查找文件中的数据: 打开文件:使用...
    99+
    2024-05-14
    c语言
  • c语言怎么求回文数
    c 语言求回文数的方法:1. 读取数字;2. 循环反转数字;3. 比较反转后数字与原始数字;4. 相等则为回文数,否则不是。 如何使用 C 语言求回文数 什么是回文数? 回文数是指从左...
    99+
    2024-05-14
    c语言
  • 如何在 Golang 中从 panic 中恢复?
    在 go 中,使用 recover 函数从 panic 中恢复,该函数从函数栈中返回最近的 panic 值。实战中,可以处理 io.eof 异常,例如:打开文件,使用 defer 捕获 ...
    99+
    2024-05-14
    golang panic
  • c语言怎么判断一个数是整数
    判断一个数在 c 语言中是否为整数:使用 fmod() 函数计算该数除以 1 的余数。如果余数为 0,则该数是整数;否则,该数不是整数。 如何判断一个数在 C 语言中是否为整数 在 C...
    99+
    2024-05-14
    c语言
  • 如何在 Golang 并发环境中处理错误?
    在 go 并发环境中处理错误的有效方法包括:异常处理(panic/recover): 适用于处理意外错误,通过 panic 引发异常,再用 recover 捕获。错误通道: 用来将并发 ...
    99+
    2024-05-14
    golang 错误处理
  • c语言怎么跳出两层for循环
    直接跳出两层 c 语言嵌套 for 循环的方法有三种:使用 break 语句直接跳出。使用 goto 语句跳转到指定标签,继续执行。使用标志变量记录跳出条件,外部 for 循环根据标志值...
    99+
    2024-05-14
    c语言
  • c语言怎么让制表对齐
    c语言中可通过以下两种方法对齐制表符:使用printf()函数的%n和%*c格式说明符计算字节偏移量并插入制表符。使用snprintf()函数将数据写入缓冲区,计算偏移量,写入制表符字符...
    99+
    2024-05-14
    c语言
  • C++ 智能指针和内存管理在高性能服务器架构中的重要性
    在高性能服务器架构中,c++++智能指针通过以下方式优化了内存管理:自动内存释放:超出作用域时释放内存。防止内存泄漏:确保不再需要对象时释放内存。跟踪资源所有权:便于调试和错误处理。常见...
    99+
    2024-05-14
    c++ 内存管理 作用域
  • 用c语言怎么判断素数
    判断素数的方法有蛮力法和埃拉托斯特尼筛法。蛮力法通过逐一尝试从 2 到数字平方根的取模来判断素数,若取模结果有 0 则不是素数。埃拉托斯特尼筛法利用标记数组来跟踪从 2 到给定范围的素数...
    99+
    2024-05-14
    c语言
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作