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

 MyBatis-plus有什么特色

   1.代码生成 2.条件构造器

    对我而言,主要的目的是使用它强大的条件构建器.  

快速使用步骤:

  1.添加pom文件依赖

  1. <dependency>
  2. <groupId>org.apache.velocity</groupId>
  3. <artifactId>velocity</artifactId>
  4. <version>1.7</version>
    </dependency>
  5. <dependency>
  6. <groupId>com.baomidou</groupId>
  7. <artifactId>mybatis-plus</artifactId>
  8. <version>2.0.1</version>
    </dependency>

  注意:mybatis-plus会自动维护mybatis以及mybatis-spring的依赖,所以不需要引入后两者,避免发生版本冲突.

  2.修改配置文件

  将mybatis的sqlSessionFactory替换成mybatis-plus的即可,mybatis-plus只做了一些功能的扩展:

  1. <bean id="sqlSessionFactory" class="com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean">
  2. <property name="dataSource" ref="dataSource"/>
  3. <!-- 自动扫描Mapping.xml文件 -->
  4. <property name="mapperLocations" value="classpath:mybatis/*/*.xml"/>
  5. <property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>
  6. <property name="typeAliasesPackage" value="com.baomidou.springmvc.model.*"/>
  7. <property name="plugins">
  8. <array>
  9. <!-- 分页插件配置 -->
  10. <bean id="paginationInterceptor" class="com.baomidou.mybatisplus.plugins.PaginationInterceptor">
  11. <property name="dialectType" value="mysql"/>
  12. </bean>
  13. </array>
  14. </property>
  15. <!-- 全局配置注入 -->
  16. <property name="globalConfig" ref="globalConfig" />
    </bean>

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

  1. <bean id="globalConfig" class="com.baomidou.mybatisplus.entity.GlobalConfiguration">
  2. <!--
  3. AUTO->`0`("数据库ID自增")
  4. INPUT->`1`(用户输入ID")
  5. ID_WORKER->`2`("全局唯一ID")
  6. UUID->`3`("全局唯一ID")
  7. -->
  8. <property name="idType" value="2" />
  9. <!--
  10. MYSQL->`mysql`
  11. ORACLE->`oracle`
  12. DB2->`db2`
  13. H2->`h2`
  14. HSQL->`hsql`
  15. SQLITE->`sqlite`
  16. POSTGRE->`postgresql`
  17. SQLSERVER2005->`sqlserver2005`
  18. SQLSERVER->`sqlserver`
  19. -->
  20. <!-- Oracle需要添加该项 -->
  21. <!-- <property name="dbType" value="oracle" /> -->
  22. <!-- 全局表为下划线命名设置 true -->
  23. <property name="dbColumnUnderline" value="true" />
  24. </bean>

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

  1.新建一个User表:

  1. @TableName("user")
  2. public class User implements Serializable {
  3.  
  4. /** 用户ID */
  5. private Long id;
  6.  
  7. /** 用户名 */
  8. private String name;
  9.  
  10. /** 用户年龄 */
  11. private Integer age;
  12.  
  13. @TableField(exist = false)
  14. private String state;
  15. }

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

2.新建Dao层接口UserMapper:

  1. /**
  2. * User 表数据库控制层接口
  3. */
  4. public interface UserMapper extends BaseMapper<User> {
  5. @Select("selectUserList")
  6. List<User> selectUserList(Pagination page,String state);
  7. }

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

  3.新建UserMapper配置文件:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  3. <mapper namespace="com.baomidou.springmvc.mapper.system.UserMapper">
  4.  
  5. <!-- 通用查询结果列-->
  6. <sql id="Base_Column_List">
  7. id, name, age
  8. </sql>
  9.  
  10. <select id="selectUserList" resultType="User">
  11. SELECT * FROM sys_user WHERE state=#{state}
  12. </select>
  13. </mapper>

  4.新建service层类UserService:

  1. /**
  2. *
  3. * User 表数据服务层接口实现类
  4. *
  5. */
  6. @Service
  7. public class UserService extends ServiceImpl<UserMapper, User>{
  8. public Page<User> selectUserPage(Page<User> page, String state) {
  9. page.setRecords(baseMapper.selectUserList(page,state));
  10. return page;
  11. }
  12. }

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

  5,新建controller层UserController

  1. @Controller
  2. public class UserController extends BaseController {
  3.  
  4. @Autowired
  5. private IUserService userService;
  6.  
  7. @ResponseBody
  8. @RequestMapping("/page")
  9. public Object selectPage(Model model){
  10.  
  11. Page page=new Page(1,10);
  12. page = userService.selectUserPage(page, "NORMAL");
  13. return page;
  14. }

  以上就完成了一个基本的功能,下面来看一下它的条件构建器.

mybatis-plus的条件构建器

  首先看一个条件构建器实例的简单实用.

  1. public void test(){
  2. EntityWrapper ew=new EntityWrapper();
  3. ew.setEntity(new User());
  4. String name="wang";
  5. Integer age=16;
  6. ew.where("name = {0}",name).andNew("age > {0}",age).orderBy("age");
  7. List<User> list = userService.selectList(ew);
  8. Page page2 = userService.selectPage(page, ew);
  9. }

  这里使用了一个条件包装类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等语法,具体构建方法可以灵活组合.

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

参考文档

mybaits-plus官方文档

 

mybatis-plus快速入门使用的更多相关文章

  1. mybatis框架快速入门

    通过快速入门示例,我们发现使用mybatis 是非常容易的一件事情,因为只需要编写 Dao 接口并且按照 mybatis要求编写两个配置文件,就可以实现功能.远比我们之前的jdbc方便多了.(我们使用 ...

  2. MyBatis(1)——快速入门

    MyBatis 简介 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为 ...

  3. (转) MyBatis(1)——快速入门

    MyBatis 简介 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为 ...

  4. mybatis的快速入门

    说明: 在这个部分,会写个简单的入门案例. 然后,会重新写一个,更加严格的程序案例. 一:案例一 1.最终的目录结构 2.新建一个普通的Java项目,并新建lib 在项目名上右键,不是src. 3.导 ...

  5. spring3.0+mybatis+spring快速入门

    一.首先奉上项目目录结构: 说明: dao,mapping,model包下的所有内容可以使用Generator工具自助生成. 具体用法,可以网上学习一下,比较简单,主要做以下工作: 1.提供相关的数据 ...

  6. MyBatis框架——快速入门

    主流的ORM框架(帮助开发者实现数据持久化工作的框架): 1.MyBatis: 半自动化ORM框架,半自动:指框架只完成一部分功能,剩下的工作仍需开发者手动完成. MyBatis 框架没有实现 POJ ...

  7. Mybatis框架 的快速入门

    MyBatis 简介 什么是 MyBatis? MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除 了几乎所有的 JDBC 代码和参数的手工设置以及结果 ...

  8. MyBatis学习总结(一)——MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  9. MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  10. MyBatis学习总结(一)——MyBatis快速入门(转载)

    本文转载自http://www.cnblogs.com/jpf-java/p/6013537.html MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了 ...

随机推荐

  1. Python3基础-高级用法

    写在前面:本文主要是python高级练习部分,介绍了一些高级用法,这些都是零散的小知识,这些可以与函数式编程合在一起使用. 函数式编程1:Python中提供的函数式编程主要有: map(函数,可迭代式 ...

  2. 潭州课堂25班:Ph201805201 django 项目 第四课 项目搭建 课堂笔记)

    创建一用户,授予对这个 myblog 库的所有表的权限(.*),在任何 ip 地址中访问(@“%”), 刷新: 退出,用新创建的用户登录,并进入这个库, 在昨天创建的项目中,配置文件中 为了数据库的案 ...

  3. Django content-type 使用

    1.models class PricePolicy(models.Model): """价格与有课程效期表""" content_type ...

  4. vue父页面给子页面传递数据

    父页面: <template> <div>{{msg}} <Son title='向子文件传递数据' :data='data' :lifemsg ='lifemsg' : ...

  5. Sunscreen [POJ3614] [贪心]

    描述 C (1 ≤ C ≤ 2500) 头奶牛在海滩边晒太阳,要避免在日光浴时产生难看的灼伤,每头奶牛必须用防晒霜覆盖它的皮肤.第 i 头奶牛有一个最小和最大 SPF 值 (1 ≤ minSPFi ≤ ...

  6. C# Json序列化去掉k__BackingField问题的解决方案

    方案一: 如果是WebAPI,可以加入全局设置: GlobalConfiguration.Configuration.Formatters.JsonFormatter.SerializerSettin ...

  7. 咏南APP(手机)开发框架

    咏南APP(手机)开发框架 有意者可向咏南索取DEMO. 基于DELPHI官方的FIREMONKEY类库构建,不使用任何三方控件. 原生手机框架,支持各种手机硬件操作. 主界面 聊天 照相并分享 短信 ...

  8. Javascript数组(一)排序

    一.简介首先,我们来看一下JS中sort()和reverse()这两个函数的函数吧reverse();这个函数是用来进行倒序,这个没有什么可说的,所谓倒序就是大的在前面,小的在后面. 比如: var ...

  9. Css3 实现循环留言滚动效果(一)

    一.常见留言滚动效果示例 html代码 <div class="runList"> <div class="runitem"> < ...

  10. Python的pandas

    pandas 是python中很重要的组件,网上关于pandas 的文章也很多,比如Python科学计算之Pandas 和 Python数据分析入门 Pandas基于两种数据类型:series与dat ...