Mybatis-Plus(三)--Mybatis-Plus配置和条件构造器

这篇具有很好参考价值的文章主要介绍了Mybatis-Plus(三)--Mybatis-Plus配置和条件构造器。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一.配置

在MP中有大量的配置,其中有一部分是Mybatis原生的配置,另一部分是MP的配置,详情:https://mybatis.plus/config

1.基本配置

【1】configLocation--自己单独的MyBatis配置的路径

#MyBatis配置文件位置,如果您有单独的MyBatis配置,请将其路径配置到configLocation中
mybatis-plus.config-location=classpath:mybatis-config.xml

SpringMVC的xml中写法:

<bean id="sqlSessionFactory"
class="com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean">
    <property name="configLocation" value="classpath:mybatis-config.xml"/>
</bean>

【2】mapperLocations--MyBatis Mapper所对应的XML文件位置


如果你在Mapper中有自定义方法(XML中有自定义实现),需要进行配置,告诉Mapper所对应的XML文件位置。

mybatis-plus.mapper-locations=classpath*:mybatis/*.xml

SpringMVC的xml中写法:

<bean id="sqlSessionFactory"
class="com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean">
    <property name="mapperLocations" value="classpath*:mybatis/*.xml"/>
</bean>

Maven多模块项目的扫描路径需以classpath*:开头(即加载多个jar包下的XML文件)

【3】typeAliasesPackage--给包中的类注册别名,使得Mapper对应的XML文件中可以直接使用类名,而不用使用全限定的类名 
 

mybatis-plus.type-aliases-package=cn.itcast.mp.pojo

SpringMVC的xml中写法:

<bean id="sqlSessionFactory"
class="com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean">
    <property name="typeAliasesPackage" 
value="com.baomidou.mybatisplus.samples.quickstart.entity"/>
</bean>

2.进阶配置(MyBatis原生的配置)

本部分的配置大都为MyBatis原生支持的配置,这意味这您可以通过MyBatis XML配置文件的形式进行配置。

【1】mapUnderscoreToCamelCase--开启自动驼峰命名规则映射

#关闭自动驼峰映射,该参数不能和mybatis-plus.config-location同时存在
mybatis-plus.configuration.map-underscore-to-camel-case=false

【2】cacheEnable--全局地开启或关闭配置文件中的所有映射器已经配置的任何缓存

mybatis-plus.configuration.camel-enabled-=false

3.DB策略配置

【1】idType--全局默认主键属性,设置后,即可省略实体对象中的@TableId(type=IdType.AUTO)配置。

mybatis-plus.global-config.db-config.id-type=auto

【2】tablePrefix--表名前缀,全局配置后可以省略@TableName属性

mybatis-plus.global-config.db-config.table-prefix=tb_

二.条件构造器

接下去,我们重点学习AbstractWrapper以及其子类

【1】allEq

QueryWrapper<User> wrapper=new QueryWrapper<>();
        //设置条件
        Map<String,Object> params=new HashMap<>();
        params.put("name","曹操");
        params.put("age","20");
        params.put("password",null);
        //SELECT * FROM tb_user WHRER password IS NULL AND name = ? AND age = ?
        wrapper.allEq(params);
        //SELECT * FROM tb_user WHRER AND name = ? AND age = ?
//        wrapper.allEq(params,false);
        List<User> users=this.userMapper.selectList(wrapper);
        for (User user:users){
            System.out.println(user);
        }

【2】基本比较操作

eq(=),ne(不等于),gt(大于),ge(大于等于),It(小于),Ie(小于等于)
between(BETWEEN 值1 AND 值2),notBetween(NOT BETWEEN 值1 AND 值2)
in--字段IN(value.get(0),value.get(1),...)
notIn--字段NOT IN(v0,v1,...)

【3】模糊查询

like,noLike,likeLeft,likeRight

//SELECT id,user_name,password,name,age,email FROM tb_user WHERE name LIKE "%曹%"
wrapper.like("name","曹");
//SELECT id,user_name,password,name,age,email FROM tb_user WHERE name not LIKE "%曹%"
wrapper.noLike("name","曹");
//SELECT id,user_name,password,name,age,email FROM tb_user WHERE name LIKE "%曹"
wrapper.likeLeft("name","曹");
//SELECT id,user_name,password,name,age,email FROM tb_user WHERE name LIKE "曹%"
wrapper.likeRight("name","曹");

【5】逻辑是or还是and(默认是and)

.or()
.and()

//SELECT id,name,age FROM tb_user WHERE name=? and age=?
wrapper.eq("name","李四")
         .or()
         .eq("age",24)
         .select("id","name","age");

【6】select--通过select方法进行指定要查询哪些字段

//SELECT id,name,age FROM tb_user WHERE name=? and age=?
wrapper.eq("name","李四")
         .eq("age",24)
         .select("id","name","age");

注:最后你还是要用类来接收,不过类中除了查询的字段其他都为空。

【7】将结果排序

orderByDesc或orderByAsc。例:

courseDetailQueryWrapper.eq("course_teacher",teacherId).orderByDesc("begin_time");

三.LambdaQueryWrapper

LambdaQueryWrapper与QueryWrapper,但是使用Lambda表达式,更安全。

写法也类似,只是将原来的字段名用实体类中的属性表示。

LambdaQueryWrapper<Like> likeLambdaQueryWrapper=new LambdaQueryWrapper<>();
likeLambdaQueryWrapper.eq(Like::getMusicId,like.getMusicId());

可以看到,从原来QueryWrapper的字段名用实体类中的属性表示。这样还有一个好处就是我们修改修改数据库的字段名字的使用就不用修改每一个的条件构造器了。文章来源地址https://www.toymoban.com/news/detail-610929.html

到了这里,关于Mybatis-Plus(三)--Mybatis-Plus配置和条件构造器的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MyBatis-Plus条件构造器[常用的模糊查询、排序查询、逻辑查询和指定字段查询案例]

    Mybatis-Plus知识点[MyBatis+MyBatis-Plus的基础运用]_心态还需努力呀的博客-CSDN博客  Mybatis-Plus+SpringBoot结合运用_心态还需努力呀的博客-CSDN博客 MyBaits-Plus中@TableField和@TableId用法_心态还需努力呀的博客-CSDN博客 MyBatis-Plus中的更新操作(通过id更新和条件更新)_心态还需努力呀的博客

    2024年02月06日
    浏览(89)
  • 【MyBatis Plus】深入探索 MyBatis Plus 的条件构造器,自定义 SQL语句,Service 接口的实现

    在前文中,介绍了 MyBatis Plus 的一些基础功能,我们发现使用MyBatis Plus 可以非常简单的就实现对单表的增删改查操作。但是这些操作对应的 SQL 语句都非常简单,如果是面对一些复杂的 SQL 或者多表查询这样的情况,就需要我们自己来重新组织 SQL 语句了。 本文将重点探索 M

    2024年02月07日
    浏览(51)
  • Java中使用es条件构造器BoolQueryBuilder

    由于es在java中查询没法像mybatis那样方便,而且es的构造器使用也比较繁琐,理解不是很方便,所以写一篇文章来记录es构造器BoolQueryBuilder查询时各种条件的构造的正确姿势。 1.构造准备 2.条件构造 must可用filter代替,查询效率会更高,因为must会对结果进行_score评估 3.构造完成

    2024年02月11日
    浏览(56)
  • MybatisPlus-CRUD,不带条件构造器的常用方法

    BaseMapper中封装好了增删改查的方法 后面直接调用就好了 测试类 ----------------------------------------------------------------- ServiceImpl中封装了方法(特别注意批量添加只有serviceImpl中有) 测试类

    2024年02月14日
    浏览(35)
  • MyBatisPlus详解(二)条件构造器Wrapper、自定义SQL、Service接口

    MyBatisPlus详解系列文章: MyBatisPlus详解(一)项目搭建、@TableName、@TableId、@TableField注解与常见配置 2.1.1 Wrapper 在BaseMapper接口提供的相关方法中,除了以id作为where条件, 还支持更加复杂的where条件,即条件构造器Wrapper : Wrapper是条件构造器的抽象类,其下有很多默认实现,继承

    2024年04月25日
    浏览(50)
  • Mybatisplus 传参参数为自定义sql, 使用条件构造器作为参数

    1 pom依赖 2 mapper 接口文件 3 mapper 的xml配置文件 4 查询 5 测试,生成的两个sql语句如下 注意 :不同的版本,可能会有部分区别,总之注意下版本

    2024年02月22日
    浏览(52)
  • Spring依赖注入之setter注入与构造器注入以及applicationContext.xml配置文件特殊值处理

    依赖注入之setter注入 在管理bean对象的组件的时候同时给他赋值,就是setter注入,通过setter注入,可以将某些依赖项标记为可选的,因为它们不是在构造对象时立即需要的。这种方式可以减少构造函数的参数数量,使得类的构造函数更加简洁。 注:既然是setter注入,则对象的

    2024年01月25日
    浏览(48)
  • Java中构造器详解(类的五成员之三:构造器)

    先看文章目录,大致了解知识点结构,直接点击文章目录可以跳转到文章指定位置。 Java的基本单位是类,类中包含五个部分,这篇写的是 构造器 。 (1)变量 (2)方法 (3)构造器 (4)初始化块 (5)内部类 ①构造器是处于Java类中的一个方法,最大的作用创建对象时执行

    2024年02月08日
    浏览(45)
  • Java 构造器

    2024年02月12日
    浏览(116)
  • 7.5 构造器详解

    7.5 构造器详解 类中的构造器也称为构造方法,是在进行创建对象的时候必须要调用的。并且构造器有以下两个特点: 必须和类的名字相同 必须没有返回类型,也不能写void 一个类即使什么都不写都会存在一个构造方法。 构造器的作用 可以实例化一些初始值,比如一些游戏

    2024年02月14日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包