springboot 集成 mybatis plus 在controller层实现的增删改查用法,以及spring boot 常用注解

注意事项:

//注意: 当使用参数@requestBody的时候,只支持post请求,所以只能用 @PostMapping ,当@requestBody里面的可以为空时候,设置required=false,
//注意: StringUtils用org.springframework.util的可以判断StringUtils.isEmpty(Object),用common下面的只能字符串
//注意: 当我们在参数传参时候,尽量用对象封装参数,例如TeacherQuery传参,然后用json格式接收, @RequestBody TeacherQuery teacherQuery,因为传速速度快,解析也快
//注意: @ApiParam(name="current",value = "当前页", required = true,说明current,limit必填

注意使用的几个注解:

rest 风格注解:

@getMapping  查询 ,/// 分页查询 由于参数有对象 @requestBody  所以 用@PostMapping

@postMapping 添加 

@putMapping  修改

@deleteMapping 删除

参数注解:@RequestBody,@PathVariable,@requestParam

其中@requestParam注解需要强调下,如果参数是list或者数组

 @RequestParam("videoIdList") List<String> videoIdList  
前台需要这样调用,“1,2,3” 默认会转型成list

// 获取用户信息方法
export function getInfo(token) {
  return request({
    url: '/eduservice/user/info',
    method: 'get',
    params:{"list":"1,2,3"}
  })
}

 

swagger注解: @api(tags="") @apiOperation @aipParam @apiModelProperty

q  

 

1:controller层查询的写法

@ApiOperation("根据id查询讲师信息")
@GetMapping("findTeacher/{id}")
public R find(@ApiParam(name="id",value = "讲师id",required = true) @PathVariable String id){
    EduTeacher byId = eduTeacherService.getById(id);
    return R.ok().data("teacher",byId);
}

2::controller层新增方法,(这块新增时候创建时间和修改时间是 默认填充的 @TableField(fill = FieldFill.INSERT_UPDATE)和@TableField(fill = FieldFill.INSERT),配置默认填充插件)

@ApiOperation("新增讲师接口")
@PostMapping("addTeacher")
public R save(@RequestBody EduTeacher eduTeacher){
    // 新增的数据不用添加创建时间和修改时间,id也不用加
    boolean save = eduTeacherService.save(eduTeacher);
    if (save){
        return R.ok();
    }
    return R.error();
}

3:controller层修改的方法,(这块修改时间是默认填充的 @TableField(fill = FieldFill.INSERT_UPDATE),并且配置了乐观锁version,@version,配置乐观锁插件;并且先查询在修改才能更新版本号)

@ApiOperation("修改讲师信息接口")
@PostMapping("updateTeacher")
public R update(@RequestBody EduTeacher eduTeacher){
    EduTeacher byId = eduTeacherService.getById(eduTeacher.getId());
    eduTeacher.setVersion(byId.getVersion());
    // 新增的数据不用添加创建时间和修改时间,id必须加上
    boolean b = eduTeacherService.updateById(eduTeacher);
    if (b){
        return R.ok();
    }
    return R.error();
}

 

4:controller层删除的方法,(这个删除是配置的逻辑删除,@TableLogic,在配置中配置了逻辑删除插件)

@ApiOperation("根据id逻辑删除讲师信息")
@DeleteMapping("deleteById/{ids}")
public R deleteById(
        @ApiParam(name="ids" ,value = "讲师id",required = true)
        @PathVariable String ids){
    boolean b = eduTeacherService.removeById(ids);
    if(b){
        return R.ok();
    }
    return R.error();
}

 

  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
首先,需要在后端环境中搭建好 Spring BootMyBatis Plus 的开发环境,可以使用 Maven 或 Gradle 等构建工具来引入所需的依赖。 接下来,需要创建一个数据表对应的 Java 实体类,并使用 MyBatis Plus 提供的注解来标识表名、主键、字段等信息。例如: ``` @Data @TableName("user") public class User { @TableId(type = IdType.AUTO) private Long id; private String name; private Integer age; } ``` 然后,创建一个 Mapper 接口,继承自 MyBatis Plus 提供的 BaseMapper 接口,用于定义增删改查等基本操作。例如: ``` public interface UserMapper extends BaseMapper<User> { } ``` 在 Spring Boot 的配置文件中,配置数据库连接信息和 MyBatis Plus 相关配置,例如: ``` spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.jdbc.Driver mybatis-plus.configuration.map-underscore-to-camel-case=true ``` 最后,在 Spring Boot 中创建一个 Controller 类,定义对应的请求处理方法,例如: ``` @RestController @RequestMapping("/user") public class UserController { @Autowired private UserMapper userMapper; @GetMapping("/{id}") public User getUserById(@PathVariable("id") Long id) { return userMapper.selectById(id); } @PostMapping("") public void createUser(@RequestBody User user) { userMapper.insert(user); } @PutMapping("/{id}") public void updateUser(@PathVariable("id") Long id, @RequestBody User user) { user.setId(id); userMapper.updateById(user); } @DeleteMapping("/{id}") public void deleteUser(@PathVariable("id") Long id) { userMapper.deleteById(id); } } ``` 这样,就完成了 Vue 和 Spring Boot 整合 MyBatis Plus 做增删改查的基本流程。在前端中,可以使用 Axios 等 HTTP 请求库来调用后端的接口。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值