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

    文章

    6511

    浏览量

    87600
  • 开发
    +关注

    关注

    0

    文章

    343

    浏览量

    40606
  • 工程
    +关注

    关注

    0

    文章

    165

    浏览量

    27566
  • spring
    +关注

    关注

    0

    文章

    332

    浏览量

    14161
收藏 人收藏

    评论

    相关推荐

    基于ORM的CRUD操作流程概述

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

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

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

    低代码可视化开发理念在物联网APP开发 精选资料分享

    低代码可视化开发理念在物联网APP开发,云编排式物联APP开发平台可通过云端可视化编排开发,边端远程自动化部署,云边协同管理运维的方式,实现物联网APP快速
    发表于 07-19 06:14

    LDO简化开关电源的设计

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

    一种面向无线传感网络的构件化开发方法

    构件化的开发模式使开发者在开发过程中能充分调用构件库中现有的构件为其服务。研究了构件化开发模式的方法和特点,针对目前无线传感器网络协议开发
    发表于 07-14 17:12 19次下载

    可控硅整流器简化开了单稳态线圈激励器电路图

    可控硅整流器简化开了单稳态线圈激励器电路图
    发表于 07-03 13:57 484次阅读
    可控硅整流器<b class='flag-5'>简化开</b>了单稳态线圈激励器电路图

    利用集成化开关稳压器简化电源设计

    利用集成化开关稳压器简化电源设计 一提到电源设计,大多数工程师都会感到挠头,他们往往会问“从哪里入手呢”。首先先必须确定电源的拓扑,包括降压、升压、f
    发表于 01-19 09:34 582次阅读
    利用集成<b class='flag-5'>化开</b>关稳压器<b class='flag-5'>简化</b>电源设计

    微软简化Visual Studio 非程序员也能开发软件

    8月4日消息,据国外媒体报道,微软将在8月23日发布Visual Studio LightSwitch测试版,旨在简化开发应用程序的过程。这个Visual Studio集成开发环境非常容易使用,甚至业务经理都能使用它
    发表于 08-04 08:48 473次阅读

    图形化开发环境LabView中文版

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

    如何简化开关电源设计

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

    利用IoT三大核心简化开发

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

    如何使用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 3444次阅读

    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 209次阅读
    MyBatis Plus如何<b class='flag-5'>简化开发</b>