微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

MyBatis Plus 入门使用详细教程

这篇文章主要介绍了MyBatis Plus 入门使用详细教程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

一、MyBatis Plus 介绍

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

MyBatis Plus 的核心功能有:支持通用的 CRUD、代码生成器与条件构造器。

通用 CRUD:定义好 Mapper 接口后,只需要继承 BaseMapper 接口即可获得通用的增删改查功能,无需编写任何接口方法配置文件条件构造器:通过 EntityWrapper (实体包装类),可以用于拼接 sql 语句,并且支持排序、分组查询等复杂的 sql代码生成器:支持一系列的策略配置与全局配置,比 MyBatis 的代码生成更好用

BaseMapper 接口中通用的 CRUD 方法

二、MyBatis Plus 集成 Spring

数据表结构

DROP TABLE IF EXISTS `tbl_employee`; CREATE TABLE `tbl_employee` ( `id` int(11) NOT NULL AUTO_INCREMENT, `last_name` varchar(50) DEFAULT NULL, `email` varchar(50) DEFAULT NULL, `gender` char(1) DEFAULT NULL, `age` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

pom 文件

com.baomidoumybatis-plus2.3junitjunit4.12com.alibabadruid1.1.10MysqLmysql-connector-java5.1.39org.springframeworkspring-context4.3.9.RELEASEOrg.springframeworkspring-orm4.3.9.RELEASE

MyBatis 全局配置文件 mybatis-config.xml

数据源 db.properties

jdbc.url=jdbc:MysqL://localhost:3306/mp jdbc.username=root jdbc.password=1234

Spring 配置文件 applicationContext.xml

三、快速体验 MyBatis Plus

实体类 Employee

@TableName(value = "tbl_employee") public class Employee { @TableId(value = "id", type = IdType.AUTO) private Integer id; @TableField(value = "last_name") private String lastName; private String email; private Integer gender; private Integer age; public Employee() { super(); } public Employee(Integer id, String lastName, String email, Integer gender, Integer age) { this.id = id; this.lastName = lastName; this.email = email; this.gender = gender; this.age = age; } // 省略 set、get 与 toString() 方法

mapper 接口

/** * 不定义任何接口方法 */ public interface EmployeeMapper extends BaseMapper {}

在测试类中生成测试的 mapper 对象

private ApplicationContext context = new ClasspathXmlApplicationContext("classpath:applicationContext.xml"); private EmployeeMapper employeeMapper = context.getBean("employeeMapper", EmployeeMapper.class);

简单查询测试

@Test public void getEmpByIdtest() { Employee employee = employeeMapper.selectById(1); System.out.println(employee); }

分页查询测试

@Test public void getEmpByPage() { Page> page = new Page(1, 5); List list = employeeMapper.selectPage(page, null); System.out.println("总记录数:" + page.getTotal()); System.out.println("总页数" + page.getPages()); System.out.println(list); }

条件构造器测试

@Test public void getEmpByName() { EntityWrapper wrapper = new EntityWrapper(); // 'last_name' 与 'age' 对应数据库中的字段 wrapper.like("last_name", "张"); wrapper.eq("age", 20); List list = employeeMapper.selectList(wrapper); System.out.println(list); }

控制台输出sql 分析日志

上面几个例子中,并没有在 EmployeeMapper 接口中定义任何方法,也没有在配置文件中编写 sql 语句,而是通过继承 BaseMapper 接口获得通用的的增删改查方法,复杂的 sql 也可以使用条件构造器拼接。

通过这两种方式已经能够满足很多的开发需求了,不过复杂的业务需求还是要编写 sql 语句的,流程和 MyBatis 一样。

PS:

完整的代码(mybatis-plus-demo 目录)传到了 GitHub,包括 sql 表结构与数据文件,点我前往~

总结

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐