【SpringBoot】实现增删改查

目录结构

查询全部数据

  • controller

    复制代码
      //注入mapper
      @Autowired
      private UserMapper userMapper;
      //查询数据
      @GetMapping
      public List<User> getUser(){
          List<User> userList = userMapper.findAll();
          return userList;
      }
  • mapper

    复制代码
      @Select("SELECT * from sys_user")
      List<User> findAll();

增加数据

  • controller

    复制代码
      //新增数据
      @PostMapping
      public Integer adduser(@RequestBody User user){
          System.out.println(user);
          return userMapper.insert(user);
      }
  • mapper

    复制代码
      @Insert("INSERT into sys_user(username,password,nickname,email,phone) VALUES (#{username},#{password},#{nickname},#{email},#{phone})")
      int insert(User user);

修改数据

  • controller

    复制代码
      //修改用户
      @PostMapping("/updateuser")
      public Integer updateuser(@RequestBody User user){
          return userMapper.update(user);
      }
  • mapper

    复制代码
      int update(User user);
  • 动态sql mapper

    <?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.spring2.mapper.UserMapper"> <update id="update"> update sys_user <set> <if test="username != null"> username = #{username}, </if> <if test="password != null"> password = #{password}, </if> <if test="nickname != null"> nickname = #{nickname}, </if> <if test="email != null"> nickname = #{email} </if> <if test="phone != null"> nickname = #{phone} </if> </set> <where> id = #{id} </where> </update> </mapper>

删除数据

  • controller

    复制代码
      //删除用户
      @DeleteMapping("/{id}")
      public Integer deletes(@PathVariable Integer id){
          return userMapper.deleteById(id);
      }
  • mapper

    复制代码
      @Delete("delete from sys_user where id = #{id}")
      Integer deleteById(Integer id);

分页查询

  • controller

    复制代码
      //分页查询
      @GetMapping("/pageList")
      public Object pageList(@RequestParam Integer  pageNum, @RequestParam Integer pageSize){
              pageNum = (pageNum - 1) * pageSize;
              //查询列表总数
              Integer selectTotal = userMapper.selectTotal();
              Map<String, Object> obj = new HashMap<>();
              obj.put("total",selectTotal);
              //分页数据
              List<User> data = userMapper.selectPage(pageNum,pageSize);
              obj.put("data",data);
              return obj;
      }
  • mapper

    复制代码
      //分页查询
      @Select("SELECT * from sys_user limit #{pageNum}, #{pageSize}")
      List<User> selectPage(@Param("pageNum") Integer pageNum, @Param("pageSize") Integer pageSize);
      //查询总数
      @Select("select count(*) from sys_user")
      Integer selectTotal();
相关推荐
Coder_Boy_1 分钟前
基于SpringAI的在线考试系统-相关技术栈(分布式场景下事件机制)
java·spring boot·分布式·ddd
独自破碎E2 分钟前
【BISHI15】小红的夹吃棋
android·java·开发语言
冻感糕人~4 分钟前
【珍藏必备】ReAct框架实战指南:从零开始构建AI智能体,让大模型学会思考与行动
java·前端·人工智能·react.js·大模型·就业·大模型学习
啦啦啦_99999 分钟前
Redis实例-2
java
alice--小文子14 分钟前
cursor-mcp工具使用
java·服务器·前端
进阶小白猿14 分钟前
Java技术八股学习Day33
java·开发语言·学习
程序员敲代码吗21 分钟前
如何通过命令行启动COMSOL的参数化、批处理和集群扫描
java·c#·bash
MX_935925 分钟前
Spring的bean工厂后处理器和Bean后处理器
java·后端·spring
市场部需要一个软件开发岗位42 分钟前
JAVA开发常见安全问题:纵向越权
java·数据库·安全
历程里程碑1 小时前
普通数组----合并区间
java·数据结构·python·算法·leetcode·职场和发展·tornado