返回顶部
首页 > 资讯 > 后端开发 > Python >Mybatis重置Criteria的正确姿势分享
  • 367
分享到

Mybatis重置Criteria的正确姿势分享

2024-04-02 19:04:59 367人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

目录mybatis重置Criteria发现问题原因如下我们想重置查询条件怎么办?得出一个结论Mybatis的Criteria用法总结Mybatis重置Criteria 开发中遇到My

Mybatis重置Criteria

开发中遇到Mybatis生成的Example通过调用createCriteria()来创建Criteria并设置查询条件的情况。

但是需要换一个查询条件再次查询时发现再次调用该方法“无效果"。

看到大多数的做法是通过new一个新的Example来查询,考虑到可能不是最好的或者最合理的做法,对此进行了简单研究。

发现问题原因如下

我们看下生成的Exmaple的源码


 public Criteria createCriteria() {
        Criteria criteria = createCriteriainternal();
        if (oredCriteria.size() == 0) {
            oredCriteria.add(criteria);
        }
        return criteria;
    }
 
    protected Criteria createCriteriaInternal() {
        Criteria criteria = new Criteria();
        return criteria;
    }

发现调用createCriteria(),虽然每次创建一个新的Criteria对象但是只有


protected List<Criteria> oredCriteria

这个列表长度为0时才会添加,进去。

查看映射的xml文件时发现,查询条件正是取自于oredCriteria。

只有调用or时才添加到该集合


 public void or(Criteria criteria) {
        oredCriteria.add(criteria);
    }

我们想重置查询条件怎么办?

两种方法:

一种是只清空Example的oredCriteria属性。

那么可以通过Example类中的getOredCriteria() 函数获取该列表后通过clear方法清空。


public List<Criteria> getOredCriteria() {
        return oredCriteria;
    }

另外一种更彻底的方法,直接调用Example的clear() 方法,将exmple对象“重置”为初始状态。


  public void clear() {
        oredCriteria.clear();
        orderByClause = null;
        distinct = false;
        pageParam = null;
    }
 

得出一个结论

遇到问题,多看源码,多看官方文档。

Mybatis的Criteria用法总结

在这里插入图片描述

用一对多内敛查询的时候,有的老铁提出left join in 但是我和同事商讨结果是用代码写处各种list然后stream存到数据库中,这样一来把计算压力从数据库存入服务器,当并发量高了,这样做的好处就体现在性能方面了。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: Mybatis重置Criteria的正确姿势分享

本文链接: https://lsjlt.com/news/159905.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Mybatis重置Criteria的正确姿势分享
    目录Mybatis重置Criteria发现问题原因如下我们想重置查询条件怎么办?得出一个结论Mybatis的Criteria用法总结Mybatis重置Criteria 开发中遇到My...
    99+
    2024-04-02
  • Mybatis重置Criteria的正确姿势是怎么样的
    这期内容当中小编将会给大家带来有关Mybatis重置Criteria的正确姿势是怎么样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Mybatis重置Criteria开发中遇到Mybatis生成的Exa...
    99+
    2023-06-22
  • springboot配置加密的正确姿势分享
    目录前言一、使用步骤1.引入依赖2. yml配置3. 使用总结主要介绍springboot项目中配置文件的加密 前言 为了保证服务器相关信息的保密,一般会采用加密的方式进行对配置文件...
    99+
    2022-11-16
    springboot配置加密 springboot配置详解
  • 调用java.lang.Runtime.exec的正确姿势分享
    目录调用java.lang.Runtime.exec的正确姿势两种方法小结一下Java Runtime.exec()注意事项1.Runtime.exec() 有四种调用方法2.得到程...
    99+
    2024-04-02
  • MySQL8.0修改密码的正确姿势分享
    目录前言mysql5.7.9之后取消了password函数,authentication_string=password("123456")会报错正确更...
    99+
    2024-04-02
  • vue中正确使用jsx语法的姿势分享
    目录前言 虚拟DOM 什么是虚拟DOM 虚拟DOM的优点渲染函数是什么 jsx 在vue3中编写jsx的两种方式 用法最后 参考前言 又到了愉快的摸鱼时间,我觉得不能荒废,H5页面...
    99+
    2024-04-02
  • JS循环中正确使用async、await的姿势分享
    目录概览(循环方式 - 常用)声明遍历的数组和异步方法for 循环中使用map 中使用forEach 中使用filter 中使用附使用小结总结概览(循环方式 - 常用) f...
    99+
    2024-04-02
  • python 折行的正确姿势
    在写 python 代码时,有时变量值是一个非常长的字符串,比如这样: line = 'this is a very very very very very very very very very very long string...
    99+
    2023-01-31
    姿势 正确 python
  • 浅谈Tomcat内存配置的正确姿势
    1.背景 虽然阅读了各大牛的博客或文章,但并没有找到特别全面的关于JVM内存分配方法的文章,很多都是复制黏贴 为了严谨,本文特别备注只介绍基于HotSpot VM虚拟机,并且基于JD...
    99+
    2024-04-02
  • 解锁redis锁的正确姿势
    解锁redis锁的正确姿势 redis是php的好朋友,在php写业务过程中,有时候会使用到锁的概念,同时只能有一个人可以操作某个行为。这个时候我们就要用到锁。锁的方式有好几种,php不能在内存中用锁,不...
    99+
    2022-06-04
    解锁 姿势 正确
  • springboot整合netty的正确姿势
    近期做一些物联网方面项目,使用到了tcp协议,之前公司做过socket短连接,网上找了一个简单的demo,很早便学习到nio方面知识,学习了《netty从入门到精通》这本书,同时也根据网上视频做了几个demo,但学习不太深入,刚好物联网项目...
    99+
    2023-10-08
    spring boot java 后端
  • 在日志中记录Java异常信息的正确姿势分享
    目录日志中记录Java异常信息遇到的问题原因分析正确的做法java异常在控制台和日志里面的打印记录1、e.printStackTrace()打印在哪里2、e.printStackTr...
    99+
    2024-04-02
  • PyCharm版本控制:配置Git的正确姿势
    PyCharm作为一款强大的集成开发环境,提供了丰富的功能来帮助开发者更高效地进行编码工作。其中,版本控制是开发过程中不可或缺的一部分。本文将重点介绍如何在PyCharm中配置Git,...
    99+
    2024-02-22
    pycharm git 版本控制 python程序
  • MySQL大表删除正确的姿势
    1、背景在生产环境有可能有删除某个不重要大表的需求,因为大表占用的大量磁盘空间,如果我们直接drop掉此表,通常需要20秒以上的时间,总会觉得会卡主MySQL,现在给大家一个正确的删除姿势。2、首先我们查看...
    99+
    2024-04-02
  • 浅谈java socket的正确关闭姿势
    java socket对应的是网络协议中的tcp,tcp的三次握手、四次挥手、11中状态什么的这里就不说了,不知道大家平常使用socket的时候如果不注意的情况下,会不会遇到各种异常...
    99+
    2024-04-02
  • Python入门的正确姿势是什么
    Python入门的正确姿势是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Python入门的正确姿势!初级开发者学Python容易陷入茫然,面对市面上种类众...
    99+
    2023-06-02
  • Python连接mysql数据库的正确姿势
    Python 数据库接口支持非常多的数据库,你可以选择适合你项目的数据库: GadFly mSQL MySQL PostgreSQL Microsoft SQL Server 2000...
    99+
    2022-06-04
    姿势 正确 数据库
  • Python怎么用(Python使用的正确姿势)
    Python是一种高级编程语言,广泛用于各种应用程序的开发。以下是Python的正确使用姿势:1. 安装Python:首先需要下载和...
    99+
    2023-09-22
    python
  • 使用Java8中Optional机制的正确姿势
    前言Java8带来的函数式编程特性对于习惯命令式编程的程序员来说还是有一定的障碍的,我们只有深入了解这些机制的方方面面才能运用自如。Null的处理在JAVA编程中是出了try catch之外的另一个头疼的问题,需要大量的非空判断模板代码,程...
    99+
    2023-05-30
    java8 optional 使用
  • 开发函数计算的正确姿势——tensor
    前言 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行...
    99+
    2023-01-31
    函数 姿势 正确
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作