0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

CRUD如何简化开发

科技绿洲 来源:Java技术指北 作者:Java技术指北 2023-09-25 15:43 次阅读

本篇文章,我们通过 MyBatis Plus 来对一张表进行 CRUD 操作,来看看是**如何简化我们开发的****。

1、创建测试表

创建 USER 表:

DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
  `ID` int(11) NOT NULL,
  `USER_NAME` varchar(32) COLLATE utf8mb4_bin DEFAULT NULL,
  `USER_AGE` int(11) DEFAULT NULL,
  PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;

向 USER 表中插入两条数据:

INSERT INTO `user` VALUES ('1', 'IT可乐', '18');
INSERT INTO `user` VALUES ('2', 'YSOcean', '22');

打开表,发现有两条数据了:

图片

2、创建 Spring Boot 工程

通过 IDEA 创建 Spring Boot 工程,如果不能连接 https://start.spring.io/ 网址,可以将网址变成 https://start.aliyun.com/ ,如下所示:

图片

3、导入依赖

< dependency >
    < groupId >com.baomidou< /groupId >
    < artifactId >mybatis-plus-boot-starter< /artifactId >
    < version >3.3.2< /version >
< /dependency >
< dependency >
    < groupId >mysql< /groupId >
    < artifactId >mysql-connector-java< /artifactId >
    < scope >runtime< /scope >
< /dependency >

首先mybatis-plus 我们导入最新版 3.3.2。另外,由于我数据采用的是 MySql,所以这里导入了 Mysql 的连接依赖。

另外,为了简化JavaBean 类的书写,我这里额外导入一个 lombok 插件依赖。

< dependency >
    < groupId >org.projectlombok< /groupId >
    < artifactId >lombok< /artifactId >
    < optional >true< /optional >
< /dependency >

通过这个依赖的相关注解,我们可以不用书写繁琐的 get/set 方法。

4、编写数据库配置文件

在 springboot 项目的 resource 目录下,新建 application.yml 文件,添加如下内容:

server:
  port: 8082

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/mybatisplus?useUnicode=true&characterEncoding=UTF-8
    username: root
    password: root
    # >= 6.x: com.mysql.cj.jdbc.Driver
    # <= 5.x: com.mysql.jdbc.Driver
    driver-class-name: com.mysql.cj.jdbc.Driver

注意:url里面填写的 mybatisplus 是我的数据库名称,注意修改,username和password分别填写自己的数据库连接名称和密码。

5、编写代码

①、实体类User.java

@Getter
@Setter
public class User {
    private Long id;

    private String userName;
    
    private String userAge;

}

②、创建UserMapper 接口

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.ys.mybatisplusstudy.entry.User;

public interface UserMapper extends BaseMapper< User > {
}

③、启动类增加@MapperScan注解

@SpringBootApplication
@MapperScan("com.ys.mybatisplusstudy.mapper")
public class MybatisplusstudyApplication {

    public static void main(String[] args) {
        SpringApplication.run(MybatisplusstudyApplication.class, args);
    }

}

如果不想在启动类加 @MapperScan 注解,也可在每个 Mapper 接口上增加 @Mapper 注解。

所有配置上面都以完成,是不是很简单,接下来我们对这张表进行CRUD 测试。

6、CRUD 测试

我们在编写 UserMapper 接口时,其继承了一个 BaseMapper 接口:

public interface UserMapper extends BaseMapper< User > {
}

我们进入到 BaseMapper 内部,发现其结构如下:

图片

这些方法便是我们常用的增删改查了,下面我们分别演示几个常用的。

①、insert:新增一条记录

@SpringBootTest
class MybatisplusstudyApplicationTests {

    @Autowired
    private UserMapper userMapper;


    /**
     * 新增一条记录
     */
    @Test
    public void testInsert(){
        User user = new User();
        user.setId(3L);
        user.setUserName("test insert");
        user.setUserAge("1");
        int insert = userMapper.insert(user);
        System.out.println("影响记录数:"+insert);
    }

}

执行完毕后,我们查看数据库:

图片

②、delete:删除记录

/**

 * 根据id删除一条记录
   */
   @Test
   public void testDeleteById(){
   int num = userMapper.deleteById(3L);
   System.out.println("删除的记录数为:"+num);
   QueryWrapper wrapper = new QueryWrapper();
   wrapper.eq("id",3L);
   userMapper.delete(wrapper);
   }

/**

 * 构造相关条件删除记录
   */
   @Test
   public void testDelete(){
   QueryWrapper wrapper = new QueryWrapper();
   wrapper.eq("USER_NAME","test insert");
   int num = userMapper.delete(wrapper);
   System.out.println("删除的记录数为:"+num);
   }

③、update:修改记录

/**

 * 根据id修改
   */
   @Test
   public void testudpateById(){
   User user = new User();
   user.setId(3L);
   user.setUserName("test update");
   int num = userMapper.updateById(user);
   System.out.println("修改的记录数为:"+num);
   }

④、select:查询记录

/**

 * 查询User表所有记录
   */
   @Test
   public void testSelectAll(){
   List< User > users = userMapper.selectList(null);
   users.forEach(x- > System.out.println(x.getId()+"-"+x.getUserName()+"-"+x.getUserAge()));
   }

/**

 * 查询指定记录
   */
   @Test
   public void testSelectWrapper(){
   QueryWrapper wrapper = new QueryWrapper();
   wrapper.eq("user_name","IT可乐");
   List< User > users = userMapper.selectList(wrapper);
   users.forEach(x- > System.out.println(x.getId()+"-"+x.getUserName()+"-"+x.getUserAge()));
   }

发现没有,做增删改查是如此的丝滑流畅,都不用写SQL语句了。

当然,这都只是单表的简单玩法,后面我们会介绍高阶玩法。

7、打印SQL语句

这里补充一个小知识点,通过如下配置,我们可以查看执行的 SQL 语句日志。

在 applicatio.yml 文件中,进行如下配置:

# 配置slq打印日志
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

图片

当然,这种配置只是把 SQL 日志打印到控制台便于我们调试,后面会介绍更加强大的 SQL 分析工具。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据
    +关注

    关注

    8

    文章

    7073

    浏览量

    89147
  • 开发
    +关注

    关注

    0

    文章

    370

    浏览量

    40865
  • 工程
    +关注

    关注

    0

    文章

    166

    浏览量

    27878
  • spring
    +关注

    关注

    0

    文章

    340

    浏览量

    14353
收藏 人收藏

    评论

    相关推荐

    基于ORM的CRUD操作流程概述

    基于ORM的CRUD
    发表于 07-12 14:16

    如何设计一个MiniGUI可视化开发工具?

    本文设计了一个MiniGUI可视化开发工具,并使用Eclipse GEF(Graphical Editing Framework)实现。
    发表于 04-27 06:27

    LDO简化开关电源的设计

        1. 简化开关电源设计    开关电源多路输出一般通过增加高频变压器反馈端来实现,这使得开关电源在设计过程中增加了设计者的工作量。应用LDO作为开关电源的输出终端,可以极大地简化开
    发表于 10-29 09:25

    可控硅整流器简化开了单稳态线圈激励器威廉希尔官方网站 图

    可控硅整流器简化开了单稳态线圈激励器威廉希尔官方网站 图
    发表于 07-03 13:57 521次阅读
    可控硅整流器<b class='flag-5'>简化开</b>了单稳态线圈激励器威廉希尔官方网站
图

    采用GEF的MiniGUI的可视化开发工具技术

    采用GEF的MiniGUI的可视化开发工具技术 1  概  述随着嵌入式系统的广泛应用,图形用户界面(Graphi
    发表于 04-16 15:10 765次阅读
    采用GEF的MiniGUI的可视<b class='flag-5'>化开发</b>工具技术

    图形化开发环境LabView中文版

    电子发烧友网站提供《图形化开发环境LabView中文版.rar》资料免费下载
    发表于 07-14 17:39 0次下载

    如何简化开关电源设计

    如何简化开关电源设计
    发表于 01-14 11:12 9次下载

    NI LabVIEW图形化开发环境与NI硬件平台,开发无人驾驶赛车

    使用NI LabVIEW图形化开发环境与NI硬件平台对智能车进行快速开发、测试以及原型,从而赢得挑战赛。
    发表于 07-19 11:22 1538次阅读

    利用IoT三大核心简化开发

    这些框架,最大程度地实现应用互操作性。 以此为基础 我们正在利用几乎适合任何环境的明确策略和独特技术,推动IoT开发。另外,Qualcomm开发者网络还提供一整套学习资源,帮助您简化设备和应用
    发表于 09-18 19:21 202次阅读

    如何使用Myeclipse进行java可视化开发

    本文档的主要内容详细介绍的是如何使用Myeclipse进行java可视化开发。实现Java的可视化开发
    发表于 01-10 10:38 5次下载
    如何使用Myeclipse进行java可视<b class='flag-5'>化开发</b>

    数据可视化开发平台PageNow上线了

    PageNow是一款基于SpringBoot+Vue构建的数据可视化开发平台。
    的头像 发表于 03-02 08:53 3660次阅读

    21489图形化开发详解:Fireware的烧写与直通

    本文介绍ADI SHARC DSP图形化开发,在一般我们都是使用vdsp++进行c语言开发的,但其实adsp 21489也可以进行图形化开发,使用sigmastudio,非常简单和方便。 图形
    的头像 发表于 08-27 15:14 7175次阅读
    21489图形<b class='flag-5'>化开发</b>详解:Fireware的烧写与直通

    JavaScript模块化开发实验---webpack入门

    JavaScript模块化开发实验---webpack入门(现代电源技术试题及答案)-文档为JavaScript模块化开发实验---webpack入门总结文档,是一份不错的参考资料,感兴趣的可以下载看看,,,,,,,,,,,,,
    发表于 09-17 14:49 7次下载
    JavaScript模块<b class='flag-5'>化开发</b>实验---webpack入门

    MyBatis Plus如何简化开发

    本篇文章,我们通过 MyBatis Plus 来对一张表进行 CRUD 操作,来看看是如何简化我们开发的。 1、创建测试表 创建 USER 表: DROP TABLE IF EXISTS
    的头像 发表于 10-09 15:08 439次阅读
    MyBatis Plus如何<b class='flag-5'>简化开发</b>

    Arm推出GitHub平台AI工具,简化开发者AI应用开发部署流程

    软件提供了无缝的开发体验。 GitHub Actions、原生 GitHub 运行器和基于 Arm 平台的 AI 框架相结合,帮助全球 2,000 万开发简化 AI 应用开发
    的头像 发表于 10-31 18:51 2349次阅读