MyBatis-Plus

MyBatis-Plus 是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

官网 MyBatis-Plus

连接池: 传统开发中,每一次请求都要建立一次数据库连接。每一次数据库连接,使用完后都得断开。频繁的数据库连接操作势必占用很多的系统资源,响应速度必定下降。另外,在高并发时,系统资源被毫无顾及的分配出去,如连接过多,也可能导致内存泄漏,服务器崩溃。

解决方案: 为数据库连接建立一个“缓冲池”(连接池)。预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕再放回去。通过设定连接池最大连接数来防止系统无休止的数据库连接。

工作流程: 当客户端请求服务器,服务器需要使用连接对象操作数据库的数据。这时,需要从连接池中申请一个连接对象。连接池会分配一个空闲连接给该客户。如果连接池中没有空闲连接,就看有没有到达最大连接数。如果没有到达最大连接数,就创建新连接分配给客户。如果已经到达最大连接,那么,请求用户会等待一段时间,在等待时间内,有连接对象被释放,则分配给等待用户。等待时间结束后,还没有连接被释放,则返回null。

Mybatis --- 环境搭建

1、导入相关依赖

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.4.2</version>
    <relativePath/>
</parent>
<dependencies>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.48</version>
    </dependency>
​
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-boot-starter</artifactId>
        <version>3.4.3</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>druid</artifactId>
        <version>1.2.9</version>
    </dependency>
</dependencies>

2、创建实体类

//声明该实体类映射的表名
@TableName("t_product")
public class ProductBean {
    //表示该列为主键列,value表示该列映射的列名
    //type = IdType.AUTO 表示该列的值使用自动增长列生成
    @TableId(value = "pk_productId",type = IdType.AUTO)
    private Integer id;
    
    //指定当前属性映射的列名
    @TableField("p_name")
    private String name;
​
    @TableField("p_createDate")
    private LocalDate createDate;
​
    @TableField("p_price")
    private Integer price;
}

3、在 resources 目录下,创建 application.yml 配置文件

spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver  #定义配置驱动类
    username: root #mysql登录用户名
    password: 123 #mysql登录密码
    url: jdbc:mysql://localhost:12345/shopDB?characterEncoding=utf8&allowMultiQueries=true 
    type: com.alibaba.druid.pool.DruidDataSource #配置连接池
    druid:
      one:
        max-active: 100 #最大连接数
        min-idle: 20 #最小连接数
        max-wait: 2000 #超时时间(ms)
​
​
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #配置日志
  type-aliases-package: com.project.bean #实体类所在包,允许用实体类类名作为别名
  mapper-locations: classpath:*/*Mapper.xml #链接 mapper文件

4、创建业务接口

public interface IProductService {
​
    public void add(ProductBean productBean);
    public void del(Integer id);
    public void update(Integer id,Integer price);
    public List<ProductBean> findAll();
    public ProductBean findById(Integer id);
    public List<ProductBean> findByItem(String name, 
LocalDate startDate,LocalDate endDate);
}

5、创建 mapper 接口

@Mapper
public interface IProductMapper extends BaseMapper<ProductBean> {
}

6、书写业务接口实现类

@Service
@Transactional//该类所有方法支持事务
public class ProductServiceImpl implements IProductService {
    @Autowired
    private IProductMapper mapper;
    @Override
    public void add(ProductBean productBean) {
        mapper.insert(productBean);//添加实体数据
    }
​
    @Override
    public void del(Integer id) {
        mapper.deleteById(id);//根据id删除实体数据
    }
​
    @Override
    public void update(Integer id, Integer price) {
        ProductBean productBean = new ProductBean();
        productBean.setId(id);
        productBean.setPrice(price);
        mapper.updateById(productBean);//按id修改实体属性
    }
​
    @Override
    public List<ProductBean> findAll() {
        return mapper.selectList(null);//查询所有
    }
​
    @Override
    public ProductBean findById(Integer id) {
        return mapper.selectById(id);//按id查询实体对象
    }
​
    @Override
    public List<ProductBean> findByItem(String name, 
LocalDate startDate, LocalDate endDate) {
        QueryWrapper<ProductBean> qw = new QueryWrapper<>();//条件集合
        if (name != null && name.length() != 0){
            qw.like("p_name",name);//like 模糊查询
        }
        if (startDate != null){
            qw.ge("p_creatDate",startDate);//ge 大于等于
        }
        if (endDate != null){
            qw.le("p_createDate",endDate);//le 小于等于
        }
        return mapper.selectList(qw);//按条件查询
    }
}

7、测试类

@RunWith(SpringRunner.class)
@SpringBootTest(classes = Main.class)//启动类类模板
public class ProductTest {
    @Autowired
    private IProductService service;
​
    @Test
    public void test(){
//        service.add(new ProductBean("999感冒灵", 
LocalDate.parse("2022-06-06"),18));
        System.out.println(service.findAll());
    }
}

分页查询

1、创建配置类,定义数据库 SQL 语句的方言。Mybatis-plus会根据配置的方言,产生分页的 SQL 语句

@Configuration
public class MyBatisPlusConfig {
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(
                new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }
​}

2、定义业务接口方法

/**
 * 动态条件分页查询
 * @param pageNO 页码
 * @param name 姓名
 * @param startDate 生产起始日期
 * @param endDate 生成结束日期
 * @return 分页对象
 */
public IPage<ProductBean> findByItem(Integer pageNO, 
String name, LocalDate startDate,LocalDate endDate);

3、定义 mapper 接口

@Mapper
public interface IProductMapper extends BaseMapper<ProductBean> {
}

4、书写业务方法

@Override
public IPage<ProductBean> findByItem(Integer pageNO,
 String name, LocalDate startDate, LocalDate endDate) {
    QueryWrapper<ProductBean> qw = new QueryWrapper<>();
    if (name != null && name.length() != 0){
        qw.like("p_name",name);
    }
    if (startDate != null){
        qw.ge("p_createDate",startDate);
    }
    if (endDate != null){
        qw.le("p_createDate",endDate);
    }
    return mapper.selectPage(new Page(pageNO,3),qw);
}

5、测试类

@RunWith(SpringRunner.class)
@SpringBootTest(classes = PlusMain.class)
public class Test {
    @Autowired
    private IProductService service;
    @org.junit.Test
    public void test(){
//        System.out.println(service.findAll());
        IPage ip = service.findByItem(1,"",null,null);
        System.out.println(ip.getRecords()//得到当前数据
                 "  " ip.getTotal()//得到总记录数
                 "  " ip.getPages()//总页数
                 "  " ip.getCurrent()//得到页码
                 "  " ip.getSize()//得到每页记录数
                 );
    }
}

Mybatis-plus 关联操作

一对多:

1、创建实体类

/**
 * 部门实体类
 */
@TableName("t_dept")
public class DeptBean {
    @TableId(value = "pk_deptId",type = IdType.AUTO)
    private Integer id;
​
    @TableField("d_name")
    private String name;
​
    @TableField(exist = false)//标识该属性没有对应的列
    private Integer emNum;
​
    @TableField(exist = false)//标识该属性没有对应的列
    private List<EmployeeBean> emList;
}
/**
 * 员工实体类
 */
@TableName("t_employee")
public class EmployeeBean {
    @TableId(value = "pk_emId",type = IdType.AUTO)
    private Integer id;
    @TableField("e_name")
    private String name;
    @TableField("e_job")
    private String job;
    @TableField("e_birthday")
    private LocalDate birthday;
    @TableField("fk_deptId")
    private Integer deptId;
    @TableField(exist = false)
    private DeptBean dept;
}

注意:如果一个属性没有对应的列,必须加上@TableField(exist = false)。否则,maybatis-plus会认为数据库表中有一个和该属性同名列。

2、建立业务接口

/**
*部门业务接口
*/
public interface IDeptService {
    /**
     * 查询所有部门,同时统计每个部门的人数
     * @return 部门集合
     */
    public List<DeptBean> findAll();
​
    /**
     * 级联添加,添加部门,同时添加该部门的员工集合
     * @param dept 部门对象
     * @param emList 新员工集合
     */
    public void add(DeptBean dept, List<EmployeeBean> emList);
​
    /**
     * 删除部门,同时级联删除部门的员工
     * @param id 部门ID
     */
    public void delCasede(Integer id);
​
    /**
     * 删除部门,同时将该部门员工外键设置为null
     * @param id 部门ID
     */
    public void delSerNull(Integer id);
​
    /**
     * 按id查询部门,同时查询该部门中所有的员工
     * @param id 部门id
     * @return 部门对象
     */
    public DeptBean findById(Integer id);
}



/**
 * 员工业务接口
 */
public interface IEmployeeService {
    /**
     * 添加员工
     * @param employee 员工对象
     */
    public void add(EmployeeBean employee);
​
    /**
     * 动态条件分页查询,同时查询每个员工所在部门的名称
     * @param pageNO 页码
     * @param deptName 部门名称
     * @param name 员工姓名
     * @return 分页对象
     */
    public IPage<EmployeeBean> findByItem(Integer pageNO,
String deptName,String name);
​
    /**
     * 按id查询员工,同时查询员工的部门信息
     * @param id 员工编号
     * @return 员工对象33
     */
    public EmployeeBean findById(Integer id);
}

3、建立 Mapper 接口

/**
*部门 mapper 接口
*/
@Mapper
public interface IDeptMapper extends BaseMapper<DeptBean> {
    @Select("SELECT d.*,COUNT(e.`pk_emId`) emNum FROM t_dept d LEFT JOIN
 t_employee e ON d.`pk_deptId`=e.`fk_deptId`\n"  
            "GROUP BY d.`pk_deptId`")
    @ResultMap("deptMap")
    public List<DeptBean> findAll();
​
    @Delete("delete from t_employee where fk_deptId=#{id};"  
            "delete from t_dept where pk_deptId=#{id};")
    public void delCasede(Integer id);
​
    @Delete("update t_employee set fk_deptId=null where fk_deptId=#{id};"  
            "delete from t_dept where pk_deptId=#{id};")
    public void delSetNull(Integer id);
}
/**
*员工 mapper 接口
*/
@Mapper
public interface IEmployeeMapper extends BaseMapper<EmployeeBean> {
​
    public void addMore(@Param("deptId") Integer deptId,
@Param("emList") List<EmployeeBean> emList);
​
    public IPage<EmployeeBean> findByItem(Page pageNO,
@Param("deptName") String deptName,@Param("name") String name);
​
}

对于联表查询的结果集,动态条件查询、循环,都需要在 mapper 文件中完成。

4、书写 mapper 文件

IDeptMapper:

<mapper namespace="com.project.mapper.IDeptMapper">
    <resultMap id="deptMap" type="DeptBean">
        <id property="id" column="pk_deptId"></id>
        <result property="name" column="d_name"></result>
        <result property="emNum" column="emNum"></result>
    </resultMap>
</mapper>

IEmployeeMapper:

<mapper namespace="com.project.mapper.IEmployeeMapper">
    <insert id="addMore">
        insert into t_employee (e_name,e_job,e_birthday,fk_deptId)
 values
        <foreach collection="emList" item="em" separator=",">
            (#{em.name},#{em.job},#{em.birthday},#{deptId})
        </foreach>
    </insert>
​
    <resultMap id="emMap" type="EmployeeBean">
        <id column="pk_emId" property="id"></id>
        <result column="e_name" property="name"></result>
        <result column="e_job" property="job"></result>
        <result column="e_birthday" property="birthday"></result>
        <result column="d_name" property="dept.name"></result>
    </resultMap>
​
    <select id="findByItem" resultMap="emMap">
        select e.*,d.d_name from t_dept d,t_employee e where
 d.pk_deptId=e.fk_deptId
        <if test="deptName != null and deptName != '' ">
            and d_name like "%"#{deptName}"%"
        </if>
        <if test="name != null and name != '' ">
            and e_name like "%"#{name}"%"
        </if>
    </select>
</mapper>

5、书写业务方法

/**
 * 部门业务方法
 */
@Service
@Transactional
public class DeptServiceImpl implements IDeptService {
​
    @Autowired
    private IDeptMapper deptMapper;
    @Autowired
    private IEmployeeMapper employeeMapper;
​
    @Override
    public List<DeptBean> findAll() {
        return deptMapper.findAll();
    }
​
    @Override
    public void add(DeptBean dept, List<EmployeeBean> emList) {
        deptMapper.insert(dept);
        employeeMapper.addMore(dept.getId(),emList);
    }
​
    @Override
    public void delCasede(Integer id) {
        deptMapper.delCasede(id);
    }
​
    @Override
    public void delSerNull(Integer id) {
        deptMapper.delSetNull(id);
    }
​
    @Override
    public DeptBean findById(Integer id) {
        DeptBean dept = deptMapper.selectById(id);
        QueryWrapper<EmployeeBean> qw = new QueryWrapper<>();
        qw.eq("fk_deptId",id);
        dept.setEmList(employeeMapper.selectList(qw));
        return dept;
    }
}
/**
 * 员工业务方法
 */
@Service
@Transactional
public class EmployeeServiceImpl implements IEmployeeService {
    @Autowired
    IEmployeeMapper employeeMapper;
    @Autowired
    IDeptMapper deptMapper;
    @Override
    public void add(EmployeeBean employee) {
        employeeMapper.insert(employee);
    }
​
    @Override
    public IPage<EmployeeBean> findByItem(Integer pageNO, 
String deptName, String name) {
        return employeeMapper.findByItem(new Page(pageNO,3),deptName,name);
    }
​
    @Override
    public EmployeeBean findById(Integer id) {
        EmployeeBean em = employeeMapper.selectById(id);
        em.setDept(deptMapper.selectById(em.getDeptId()));
  ··      return em;
    }
}

统计查询记录数

QueryWrapper<StudentBean> qw = new QueryWrapper<>();
qw.eq("fk.classId",classId);
Integer num = studentMapper.selectCount(qw);

到此这篇关于MyBatis-Plus详解的文章就介绍到这了,更多相关MyBatis-Plus详解内容请搜索Devmax以前的文章或继续浏览下面的相关文章希望大家以后多多支持Devmax!

MyBatis-Plus详解(环境搭建、关联操作)的更多相关文章

  1. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  2. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. MyBatis-Plus乐观锁插件的用法小结

    乐观锁很乐观,对任何事情都保持着一个乐观的态度,认为别人不会修改数据,所以不会上锁,只是在更新数据的时候,去判断这条数据有没有被别人修改过,这篇文章主要介绍了MyBatis-Plus乐观锁插件的用法,需要的朋友可以参考下

  4. Mybatis-Plus主键生成策略的方法

    本文主要介绍了Mybatis-Plus主键生成策略的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  5. mybatis-plus自带QueryWrapper自定义sql实现复杂查询实例详解

    MyBatis-Plus是一个MyBatis(opens new window)的增强工具,在 MyBatis的基础上只做增强不做改变,MyBatis可以无损升级为MyBatis-Plus,这篇文章主要给大家介绍了关于mybatis-plus自带QueryWrapper自定义sql实现复杂查询的相关资料,需要的朋友可以参考下

  6. Mybatis-plus:${ew.sqlselect}用法说明

    这篇文章主要介绍了Mybatis-plus:${ew.sqlselect}用法说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  7. 一文详解Mybatis-plus的介绍与使用

    Mybatis-Plus 是 MyBatis 的一个增强工具,专门针对于传统MyBatis开发中sql需要手动进行映射配置繁琐缺点的一款框架技术。本文将为大家详细讲讲Mybatis-plus的介绍与使用,感兴趣的可以了解一下

  8. Javascript基础知识详解

    本篇适合javascript新手或者学了前端一段时间,对js概念不清晰的同学。本文将讲述几点对于初学者遇到的javascript的坑,相信对javascript基础薄弱的同学,可以加深对javascript的理解

  9. MyBatis-Plus找不到Mapper.xml文件的几种解决方法

    mybatis-plus今天遇到一个问题,就是mybatis 没有读取到mapper.xml 文件,所以下面这篇文章主要给大家介绍了关于MyBatis-Plus找不到Mapper.xml文件的几种解决方法,需要的朋友可以参考下

  10. 无边框窗口代码详解

    第二部分是用来控制窗口的移动及关闭,必须放在指定的文件里。在此代码里,5个html文件分别为:1.html;代码第一部分所在load.html;所打开的窗口,是一个框架网页chromelesstit.html;代码第2部分所在contacting.html;用来显示如'PAGELOADING.."等临时信息的网页main.html;真正的主网页4个图像分别为x_a.gif;activex_d.gif;mouseDownx_o.gif;mouseOver以上三个文件分别代表关闭窗口图标的不同状态none.g

随机推荐

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. Java利用POI实现导入导出Excel表格

    这篇文章主要为大家详细介绍了Java利用POI实现导入导出Excel表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. Mybatis分页插件PageHelper手写实现示例

    这篇文章主要为大家介绍了Mybatis分页插件PageHelper手写实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助

  5. Java 阻塞队列BlockingQueue详解

    本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景,通过实例代码介绍了Java 阻塞队列BlockingQueue的相关知识,需要的朋友可以参考下

  6. Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等

  7. Java Bean 作用域及它的几种类型介绍

    这篇文章主要介绍了Java Bean作用域及它的几种类型介绍,Spring框架作为一个管理Bean的IoC容器,那么Bean自然是Spring中的重要资源了,那Bean的作用域又是什么,接下来我们一起进入文章详细学习吧

  8. 面试突击之跨域问题的解决方案详解

    跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。那怎么解决这个问题呢?接下来我们一起来看

  9. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部