详解springboot+mybatis

网友投稿 275 2022-12-01


详解springboot+mybatis

mybatis-plus的特性

无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑

损耗小:启动即会自动注入基本CURD,性能基本无损耗,直接面向对象操作

强大的 CRUD操作:内置通用 Mapper、通用Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求

支持 Lambda形式调用:通过 Lambda 表达式,方便的编写各类查询条件,无需再担心字段写错

支持主键自动生成:支持多达 4种主键策略(内含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解决主键问题

支持 ActiveRecord 模式:支持ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD 操作

支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere )

内置代码生成器:采用代码或者Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller

层代码,支持模板引擎,更有超多自定义配置等您来使用

内置分页插件:基于 MyBatis

物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通 List 查询

分页插件支持多种数据库:支持mysql、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多种数据库

内置性能分析插件:可输出 Sql 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询 - 内置全局拦截插件:提供全表 delete、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作

首先搭建好springboot项目,引入pom文件

com.baomidou

mybatis-plus-boot-starter

3.1.0

org.mybatis.spring.boot

mybatis-spring-boot-starter

2.0.1

com.gitee.sunchenbin.mybatis.actable

mybatis-enhance-actable

1.1.1.RELEASE

连接数据库这一步很关键,这里使用druid连接mysql数据库

mysql

mysql-connector-java

com.alibaba

druid-spring-boot-starter

1.1.10

application-prod.yml数据源配置文件,这里使用com.mysql.cj.jdbc.Driver的druid数据源,你也可以直接写在application.yml配置文件中

spring:

datasource:

url: jdbc:mysql://127.0.0.1:3306/lianxicrud?useUnicode=true&useSSL=false&characterEncoding=utf-8&serverTimezone=Asia/Shanghai

username: root

password: 123456

# 使用druid数据源

type: com.alibaba.druid.pool.DruidDataSource

driver-class-name: com.mysql.cj.jdbc.Driver

server:

port: 8191

新建mapper的空文件

import chttp://om.baomidou.mybatisplus.core.mapper.BaseMapper;

import com.psd.domain.User;

import org.apache.ibatis.annotations.Mapper;

@Mapper

pGATpkUEublic interface UserMapper extends BaseMapper{

}

新建service及impl文件

Service文件继续IService

Impl继承ServiceImpl实现service抽象接口

注ServiceImpl查询是直接this.list(),插入则使用userMapper.insert(user)

修改数据删除数据在单独在文章内容后文补充

import com.baomidou.mybatisplus.extension.service.IService;

import com.psd.domain.UsGATpkUEer;

import java.util.List;

public interface IUserService extends IService{

/**

* 查询所有

* @return

*/

List listAll();

/**

* id条件查询

* @return

*/

User listOne(Long id);

/***

* 保存

* @param user

* @return

*/

int insert1(User user);

}

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;

import com.psd.domain.User;

import com.psd.mapper.UserMapper;

imhttp://port com.psd.service.IUserService;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Service;

import java.util.List;

import java.util.stream.Collectors;

@Service

public class UserServiceImpl extends ServiceImpl implements IUserService{

@Autowired

private UserMapper userMapper;

//查询所有

@Override

public List listAll() {

List users = this.list();

return users;

}

//条件查询

public User listOne(Long id) {

User user = this.getById(id);

return user;

}

//保存

public int insert1(User user){

return userMapper.insert(user);

}

}

user实体

import com.baomidou.mybatisplus.annotation.TableName;

import lombok.Data;

@TableName("user")

@Data

public class User{

private long id;

private String name;

private int age;

private String email;

//..使用lombok插件省列get set方法

}

控制器应用层类

import com.psd.domain.User;

import com.psd.service.IUserService;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController

public class UserController {

@Autowired

private IUserService userService;

@GetMapping("/listAll")

public List listAll(){

List users = userService.listAll();

return users;

}

@GetMapping("/listOne")

public User listOne(){

return userService.listOne(1L);

}

//保存

@GetMapping("/save")

public void baocun1(int age,String name,String email){

User user1 = new User();

user1.setAge(age);

user1.setName(name);

user1.setEmail(email);

userService.insert1(user1);

}

}

mybatis-plus修改数据操作

@Test

public void update() {

//修改值

User user = new User();

user.setAge(“20”);

user.setName("李四");

//修改条件意思就是修改值为user.setAge(“20”);user.setName("李四");像setEmail为null的视为不变,然后条件值为id=1

UpdateWrapper userUpdateWrapper = new UpdateWrapper<>();

userUpdateWrapper.eq("id", "1");

boolean update = mapper.update(user, userUpdateWrapper);

System.out.println(update);

}

mybatis-plus删除数据操作

@Test

public void delete() {

QueryWrapper queryWrapper = new QueryWrapper<>();

//条件意思就是删除id=1的并且isNotNull指"id"字段不为空的

queryWrapper

.ge("id", 1)

.isNotNull("id");

int delete = mapper.delete(queryWrapper);

}

直接浏览器请求,那么整个过程就完成了

http://localhost:8191/save?age=18&name=张磊&email=739595798@qq.com

http://localhost:8191/user/listOne


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:java数字和中文算数验证码的实现
下一篇:SpringBoot执行定时任务@Scheduled的方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~