mybatis-plus快速入门使用
目前正在维护的公司的一个项目是一个ssm架构的java项目,dao层的接口有大量数据库查询的方法,一个条件变化就要对应一个方法,再加上一些通用的curd方法,对应一张表的dao层方法有时候多达近20个,果断决定优化一下,经过一番探索,发现了一个mybatis的好伴侣,mybatis-plus,上手容易,简洁高效,这里有官方的文档入口,文档比较详细,本来不想在重复文档内容,但是关上文档,看着自己改过的项目,还是打算在脑海里过一下使用步骤及相关注意事项,顺便记录一下.
MyBatis-plus有什么特色
1.代码生成 2.条件构造器
对我而言,主要的目的是使用它强大的条件构建器.
快速使用步骤:
1.添加pom文件依赖

- <dependency>
- <groupId>org.apache.velocity</groupId>
- <artifactId>velocity</artifactId>
- <version>1.7</version>
</dependency>- <dependency>
- <groupId>com.baomidou</groupId>
- <artifactId>mybatis-plus</artifactId>
- <version>2.0.1</version>
</dependency>

注意:mybatis-plus会自动维护mybatis以及mybatis-spring的依赖,所以不需要引入后两者,避免发生版本冲突.
2.修改配置文件
将mybatis的sqlSessionFactory替换成mybatis-plus的即可,mybatis-plus只做了一些功能的扩展:

- <bean id="sqlSessionFactory" class="com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean">
- <property name="dataSource" ref="dataSource"/>
- <!-- 自动扫描Mapping.xml文件 -->
- <property name="mapperLocations" value="classpath:mybatis/*/*.xml"/>
- <property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>
- <property name="typeAliasesPackage" value="com.baomidou.springmvc.model.*"/>
- <property name="plugins">
- <array>
- <!-- 分页插件配置 -->
- <bean id="paginationInterceptor" class="com.baomidou.mybatisplus.plugins.PaginationInterceptor">
- <property name="dialectType" value="mysql"/>
- </bean>
- </array>
- </property>
- <!-- 全局配置注入 -->
- <property name="globalConfig" ref="globalConfig" />
</bean>

在上面的配置中,除了mybatis的常规配置,多了一个分页插件的配置和全局配置,mybatis-plus提供了很方便的使用分页的插件,还有一个全局配置如下:

- <bean id="globalConfig" class="com.baomidou.mybatisplus.entity.GlobalConfiguration">
- <!--
- AUTO->`0`("数据库ID自增")
- INPUT->`1`(用户输入ID")
- ID_WORKER->`2`("全局唯一ID")
- UUID->`3`("全局唯一ID")
- -->
- <property name="idType" value="2" />
- <!--
- MYSQL->`mysql`
- ORACLE->`oracle`
- DB2->`db2`
- H2->`h2`
- HSQL->`hsql`
- SQLITE->`sqlite`
- POSTGRE->`postgresql`
- SQLSERVER2005->`sqlserver2005`
- SQLSERVER->`sqlserver`
- -->
- <!-- Oracle需要添加该项 -->
- <!-- <property name="dbType" value="oracle" /> -->
- <!-- 全局表为下划线命名设置 true -->
- <property name="dbColumnUnderline" value="true" />
- </bean>

至此,配置工作就算大功告成了,接下来通过一个简单的例子来感受一下它的使用.
1.新建一个User表:

- @TableName("user")
- public class User implements Serializable {
- /** 用户ID */
- private Long id;
- /** 用户名 */
- private String name;
- /** 用户年龄 */
- private Integer age;
- @TableField(exist = false)
- private String state;
- }

这里有两个注解需要注意,第一是@tableName("user"),它是指定与数据库表的关联,这里的注解意味着你的数据库里应该有一个名为user的表与之对应,并且数据表的列名应该就是User类的属性,对于User类中有而user表中没有的属性需要加第二个注解@TableField(exist = false),表示排除User类中的属性.
2.新建Dao层接口UserMapper:

- /**
- * User 表数据库控制层接口
- */
- public interface UserMapper extends BaseMapper<User> {
- @Select("selectUserList")
- List<User> selectUserList(Pagination page,String state);
- }

dao接口需要实现Basemapper,这样就能够使用封装好的很多通用方法,另外也可以自己编写方法,@select注解引用自第三步的UserMapper文件
3.新建UserMapper配置文件:

- <?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.baomidou.springmvc.mapper.system.UserMapper">
- <!-- 通用查询结果列-->
- <sql id="Base_Column_List">
- id, name, age
- </sql>
- <select id="selectUserList" resultType="User">
- SELECT * FROM sys_user WHERE state=#{state}
- </select>
- </mapper>

4.新建service层类UserService:

- /**
- *
- * User 表数据服务层接口实现类
- *
- */
- @Service
- public class UserService extends ServiceImpl<UserMapper, User>{
- public Page<User> selectUserPage(Page<User> page, String state) {
- page.setRecords(baseMapper.selectUserList(page,state));
- return page;
- }
- }

UserService继承了ServiceImpl类,mybatis-plus通过这种方式为我们注入了UserMapper,这样可以使用service层默认为我们提供的很多方法,也可以调用我们自己在dao层编写的操作数据库的方法.Page类是mybatis-plus提供分页功能的一个model,继承了Pagination,这样我们也不需要自己再编写一个Page类,直接使用即可.
5,新建controller层UserController

- @Controller
- public class UserController extends BaseController {
- @Autowired
- private IUserService userService;
- @ResponseBody
- @RequestMapping("/page")
- public Object selectPage(Model model){
- Page page=new Page(1,10);
- page = userService.selectUserPage(page, "NORMAL");
- return page;
- }

以上就完成了一个基本的功能,下面来看一下它的条件构建器.
mybatis-plus的条件构建器
首先看一个条件构建器实例的简单实用.

- public void test(){
- EntityWrapper ew=new EntityWrapper();
- ew.setEntity(new User());
- String name="wang";
- Integer age=16;
- ew.where("name = {0}",name).andNew("age > {0}",age).orderBy("age");
- List<User> list = userService.selectList(ew);
- Page page2 = userService.selectPage(page, ew);
- }

这里使用了一个条件包装类EntityWrapper,来进行对sql语句的拼装,原理也很好理解,上面的代码中,第一个list查询的结果就是查询数据库中name=wang并且age>16岁的所有记录并按照age排序.而第二个查询就是再多加一个分页的功能.
基本上来说,使用EntityWrapper可以简单地完成一些条件查询,但如果查询方法使用频率很高的话还是建议自己写在UserMapper里.
那么自定义的mapper方法能不能使用EntityWrapper呢,当然也是可以的.
文档中给了一个这样的例子.
1.在Mappper中定义:
List<User> selectMyPage(RowBounds rowBounds, @Param("ew") Wrapper<T> wrapper);
2.在mapper文件中定义:
<select id="selectMyPage" resultType="User">
SELECT * FROM user ${ew.sqlSegment}
</select>
对于EntityMapper的条件拼接,基本可以实现sql中常用的where,and,or,groupby,orderby等语法,具体构建方法可以灵活组合.

- @Test
- public void testTSQL11() {
- /*
- * 实体带查询使用方法 输出看结果
- */
- ew.setEntity(new User(1));
- ew.where("name={0}", "'zhangsan'").and("id=1")
- .orNew("status={0}", "0").or("status=1")
- .notLike("nlike", "notvalue")
- .andNew("new=xx").like("hhh", "ddd")
- .andNew("pwd=11").isNotNull("n1,n2").isNull("n3")
- .groupBy("x1").groupBy("x2,x3")
- .having("x1=11").having("x3=433")
- .orderBy("dd").orderBy("d1,d2");
- System.out.println(ew.getSqlSegment());
- }

参考文档
mybatis-plus快速入门使用的更多相关文章
- mybatis框架快速入门
通过快速入门示例,我们发现使用mybatis 是非常容易的一件事情,因为只需要编写 Dao 接口并且按照 mybatis要求编写两个配置文件,就可以实现功能.远比我们之前的jdbc方便多了.(我们使用 ...
- MyBatis(1)——快速入门
MyBatis 简介 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为 ...
- (转) MyBatis(1)——快速入门
MyBatis 简介 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为 ...
- mybatis的快速入门
说明: 在这个部分,会写个简单的入门案例. 然后,会重新写一个,更加严格的程序案例. 一:案例一 1.最终的目录结构 2.新建一个普通的Java项目,并新建lib 在项目名上右键,不是src. 3.导 ...
- spring3.0+mybatis+spring快速入门
一.首先奉上项目目录结构: 说明: dao,mapping,model包下的所有内容可以使用Generator工具自助生成. 具体用法,可以网上学习一下,比较简单,主要做以下工作: 1.提供相关的数据 ...
- MyBatis框架——快速入门
主流的ORM框架(帮助开发者实现数据持久化工作的框架): 1.MyBatis: 半自动化ORM框架,半自动:指框架只完成一部分功能,剩下的工作仍需开发者手动完成. MyBatis 框架没有实现 POJ ...
- Mybatis框架 的快速入门
MyBatis 简介 什么是 MyBatis? MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除 了几乎所有的 JDBC 代码和参数的手工设置以及结果 ...
- MyBatis学习总结(一)——MyBatis快速入门
一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...
- MyBatis快速入门
一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...
- MyBatis学习总结(一)——MyBatis快速入门(转载)
本文转载自http://www.cnblogs.com/jpf-java/p/6013537.html MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了 ...
随机推荐
- Python3基础-高级用法
写在前面:本文主要是python高级练习部分,介绍了一些高级用法,这些都是零散的小知识,这些可以与函数式编程合在一起使用. 函数式编程1:Python中提供的函数式编程主要有: map(函数,可迭代式 ...
- 潭州课堂25班:Ph201805201 django 项目 第四课 项目搭建 课堂笔记)
创建一用户,授予对这个 myblog 库的所有表的权限(.*),在任何 ip 地址中访问(@“%”), 刷新: 退出,用新创建的用户登录,并进入这个库, 在昨天创建的项目中,配置文件中 为了数据库的案 ...
- Django content-type 使用
1.models class PricePolicy(models.Model): """价格与有课程效期表""" content_type ...
- vue父页面给子页面传递数据
父页面: <template> <div>{{msg}} <Son title='向子文件传递数据' :data='data' :lifemsg ='lifemsg' : ...
- Sunscreen [POJ3614] [贪心]
描述 C (1 ≤ C ≤ 2500) 头奶牛在海滩边晒太阳,要避免在日光浴时产生难看的灼伤,每头奶牛必须用防晒霜覆盖它的皮肤.第 i 头奶牛有一个最小和最大 SPF 值 (1 ≤ minSPFi ≤ ...
- C# Json序列化去掉k__BackingField问题的解决方案
方案一: 如果是WebAPI,可以加入全局设置: GlobalConfiguration.Configuration.Formatters.JsonFormatter.SerializerSettin ...
- 咏南APP(手机)开发框架
咏南APP(手机)开发框架 有意者可向咏南索取DEMO. 基于DELPHI官方的FIREMONKEY类库构建,不使用任何三方控件. 原生手机框架,支持各种手机硬件操作. 主界面 聊天 照相并分享 短信 ...
- Javascript数组(一)排序
一.简介首先,我们来看一下JS中sort()和reverse()这两个函数的函数吧reverse();这个函数是用来进行倒序,这个没有什么可说的,所谓倒序就是大的在前面,小的在后面. 比如: var ...
- Css3 实现循环留言滚动效果(一)
一.常见留言滚动效果示例 html代码 <div class="runList"> <div class="runitem"> < ...
- Python的pandas
pandas 是python中很重要的组件,网上关于pandas 的文章也很多,比如Python科学计算之Pandas 和 Python数据分析入门 Pandas基于两种数据类型:series与dat ...