• Mybatis-Plus


    转发自:https://www.cnblogs.com/fingerboy/p/6657118.html

    使用Jeecg与此对比,通用Mapper与Mybatis-Plus类似

    MyBatis-plus有什么特色

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

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

              2.3版本使用EntityWapper条件构造器、3.0后改为QueryWapper  

              3.0主要使用QueryWrapper 和UpdateWrapper,JDK1.8使用LambdaQueryWrapper和LambdaUpdateWrapper(继承前者)

    快速使用步骤:

      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<UserselectMyPage(RowBounds rowBounds@Param("ew") Wrapper<T> wrapper);

       2.在mapper文件中定义:

    <select id="selectMyPageresultType="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());
    }
  • 相关阅读:
    Atitit 图片验证码功能设计文档总结目录1.1. 使用图片验证码img src标签设置图片。。验证码图片有png,jpg,svg等格式。。 11.2. Php png图像 11.3. P
    Atitt php script lan debug bp 最佳实践调试php目录1.1. Error_log 11.2. Echo vs log法 11.3. 输出与debug信息昏药问题
    Atitit 项目分析与统计目录1. 静态分析+动态分析 。其中, 12. 模块分析,与模块位置idx 13. 编程语言类型与版本 13.1. 类库统记表 类型与版本 23.2. 中间
    Atitit 增强代码健壮性 出错继续执行恢复模式,就像vbs那样我以为我可以使用Try/Catch,但是我找不到异常后是否可以继续执行代码,并且找不到如何在最后显示错误消息。目录PHP
    Atitit bootsAtitit bootstrap布局 栅格.docx目录1. 简述container与container-fluid的区别 11.1.1. 在bootstrap中的布局
    Atitit php读取数据库记录集合并循环修改展示//------------------------ini db sys$dbstr = “mysql:host=“ . $mysql_con
    Atitit 验证码功能修复总结文档原有的tp5里面的验证码不知怎么有问题了,试图在tp5框架内修复无果。。使用了新的验证码组件 “lifei6671/php-captcha“: “0.
    Atitt 支付业务 银行国际代码(SWIFT Code银行国际代码(SWIFT Code)是由SWIFT协会提出并被ISO通过的银行识别代码,凡该协会的成员银行都有自己特定的SWIFT代码
    Atitit img hot click link 图像背景拉伸100%Map area trouble..So body backgrd img mode...is easy...No
    Atitit doc mng 文档管理总结目录1. 主要几大内容 12. 存储管理 22.1. 一般来说 ,文档存储在IM网盘note邮箱blog wiki等地 22.2. 文档格式与体
  • 原文地址:https://www.cnblogs.com/Bkxk/p/10175117.html
Copyright © 2020-2023  润新知