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-Plus工具快速入门

    MyBatis-Plus官方文档:http://mp.baomidou.com/#/quick-starthttp://mp.baomidou.com/guide/#%E7%89%B9%E6%80%A ...

  2. 版本控制工具Git工具快速入门-Linux篇

    版本控制工具Git工具快速入门-Linux篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.版本管理系统的介绍 1>.版本管理系统的特点 1.1>.自动生成备份: ...

  3. 版本控制工具Git工具快速入门-Windows篇

    版本控制工具Git工具快速入门-Windows篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 最近在学习Golang语言,之前的开发环境在linux上开发的,后来由于办公用的是w ...

  4. MyBatis 框架之快速入门程序

    一.使用 IDEA 快速创建 Maven 项目 关于如何快速创建 Maven 项目,这个可以参考下面这篇文章: Maven 项目管理工具基础入门系列(一) 二.快速配置 MyBatis 依赖 jar ...

  5. Mybatis框架 的快速入门

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

  6. sqlDeveloper工具快速入门

    场景 我们在连接oracle数据库的时候 常用方式一般有以下三种: pl/sql deceloper navicat sqlDeveloper 其中, pl/sql developer是最经典的,也是 ...

  7. 优雅高效的MyBatis-Plus工具快速入门使用

    目前正在维护的公司的一个项目是一个ssm架构的java项目,dao层的接口有大量数据库查询的方法,一个条件变化就要对应一个方法,再加上一些通用的curd方法,对应一张表的dao层方法有时候多达近20个 ...

  8. 10- JMeter5.1.1 工具快速入门

    什么是JMeter JMeter是Apache组织开发的开源软件,由Java语言实现. 主要用于软件系统性能测试,他最初被设计用于web测试,后来被扩展到其他领域. Jmeter特点 http://w ...

  9. 持久层之 MyBatis: 第一篇:快速入门

    MyBatis入门到精通 JDBC回顾 1.1.认识MyBatis 1.1.使用IDEA创建maven工程 1.2.引入mysql依赖包 1.3.准备数据 1.4 使用JDBC手写MyBatis框架 ...

随机推荐

  1. flask-login2的简单使用

    #coding:utf8 from flask import Flask, render_template, request, redirect, url_for, flash, abort from ...

  2. 小任务之Canvas绘制时钟

    背景图的绘制(大圆.数字.小圆点) 掌握基础知识:圆的绘制(arc方法),关于圆的弧度的计算,数学中关于sin cos的用法 圆的弧度为2*Math.PI 12个数字分得弧度每个为2*Math.PI/ ...

  3. 一个对inner jion ...on 的sql多表联合查询的练习

    create database practiceSql; use practiceSql; -- create table student( `id` bigint not null auto_inc ...

  4. Express (Routing、Middleware、托管静态文件、view engine 等等)

    1. Express 简介 Express 是基于 Node.js 平台,快速.开放.极简的 web 开发框架,它提供一系列强大的特性,帮助你创建各种 Web 和移动设备应用. Express 不对 ...

  5. eclipse插件开发常见的问题及解决办法

    莫名其妙地我的某个Plug-in Projects出现了这样的Error:An API baseline has not been set for the current workspace.虽然后来 ...

  6. 02_zookeeper配置

    [zoo.cfg] * tickTime:用于计算的时间单元.比如session超时:N*tickTime * initLimit:用于集群,允许从节点连接并且同步到master节点的初始化连接时间, ...

  7. 开启VS2017之旅

  8. tensorflow: a Implementation of rotation ops (旋转的函数实现方法)

    tensorflow 旋转矩阵的函数实现方法 关键字: rot90, tensorflow 1. 背景 在做数据增强的操作过程中, 很多情况需要对图像旋转和平移等操作, 针对一些特殊的卷积(garbo ...

  9. 面试准备之一Python

    基本数据类型 函数 模块与包 面向对象 网络编程 垃圾回收机制 G 并发编程

  10. 异步nodejs代码的同步样子写法样例

    异步nodejs代码的同步样子写法样例 js的异步嵌套太深代码将不好看.尤其在用node的时候这种情况会大量出现. 这里用node连接redis,做一个用户注册的简单例子来说明.例如用redis做存储 ...