1.?修改修改?mybatisԴ??
2.MyBatis 源码解析:映射文件的加载与解析(上)
3.Mybatis源码剖析(懒加载原理)
4.把Mybatis Generator生成的代码加上想要的注释
??mybatisԴ??
在实际开发过程中,我遇到了mybatis的修改修改一个问题,觉得很有必要记录下来并分享给大家。修改修改
这个坑的修改修改具体情况是这样的:在mybatis中,OgnlOps.equal(0,修改修改"")返回的是true,这违背了我们的修改修改弹球游戏源码编辑常识,并且会带来一些问题。修改修改
接下来,修改修改我将按照遇到问题 -> 分析问题 -> 解决问题的修改修改思路,用追踪源码的修改修改方法,对这个问题进行剖析。修改修改
同时,修改修改我会分享一下我是修改修改如何通过逆向排查的方法,通过Debug模式找到关键源码,修改修改并解决这个问题的修改修改。
本文源码:mybatis 3.5.3版本。
背景介绍和需求分析
为了简化问题,我们假设有一个订单表,表结构如下:
为了方便说明,我们假设表里面只有两条数据:订单号为的订单状态为0(关闭),订单号为的订单状态为1(开启)。
已经开发好的功能是模糊查询订单名称,接口如下:
现在需要在已有功能上添加一个根据状态过滤订单的android 4.1源码下载功能。
假设某个页面有这样的一个下拉框,可以根据订单状态过滤订单数据。
准备开发
现在明确了需求,根据订单状态进行过滤。
很简单,最主要的修改地方就是对mapper.xml的修改。
开始自测,遇到问题
为了确保功能的正确性,我进行了单元测试,分别传入状态0和1,预期的结果是各自查询出一条数据。
然而,执行结果却与预期不符,status=0时查询出2条数据,status=1时查询出1条数据。
当时我意识到这个问题可能并不简单,于是决定分析原因。
分析问题
为了找到问题的根源,我首先将sql打印出来,查看最终执行的sql。
通过分析sql,我发现当status为0时,大灰狼8.62源码mybatis并没有给我们拼接where关键字。
逆向排查法
为了定位问题,我通过日志找到了关键源码,并使用逆向排查的方法进行追踪。
最终,我发现问题的根源在于mybatis中的OgnlOps.equal(0,"")返回了true。
关键源码
通过分析源码,我找到了导致这个问题的关键代码,并解决了这个问题。
解决问题
为了解决这个问题,我修改了mapper.xml文件中的if标签,最终实现了预期效果。
总结
这次的经历让我深刻认识到,在开发过程中遇到问题时,要善于分析、思考和总结,才能不断提升自己的技能。
MyBatis 源码解析:映射文件的加载与解析(上)
MyBatis 的映射文件是其核心组成部分,用于配置 SQL 语句、二级缓存及结果集映射等功能,是其区别于其他 ORM 框架的重要特色。 在解析映射文件时,卖号网站源码MyBatis 通过调用 XMLMapperBuilder#parse 方法实现加载与解析操作。此方法首先判断映射文件是否已解析,若未解析则调用 XMLMapperBuilder#configurationElement 方法解析所有配置,并注册当前映射文件关联的 Mapper 接口。对于处理异常的标签,MyBatis 会记录至 Configuration 对象并尝试二次解析。 解析流程主要涉及以下几个关键步骤:缓存配置(cache 标签):MyBatis 采用缓存设计,分为一级缓存和二级缓存。解析 cache 标签时,首先获取相关属性配置,然后使用 CacheBuilder 创建缓存对象,并记录到 Configuration 对象。
缓存引用(cache-ref 标签):标签默认限定在 namespace 范围内,用于引用其它命名空间中的缓存对象。解析过程中记录引用关系,然后从 Configuration 中获取引用的缓存对象。
结果集映射(resultMap 标签):解析 resultMap 标签配置,构建 ResultMap 对象,并将其记录到 Configuration 中。
SQL 语句(sql 标签):通过 sql 标签配置复用的 SQL 语句片段,解析后记录至 Configuration 的 sqlFragments 属性中。
核心数据库操作(select / insert / update / delete 标签):解析这些标签时,360新标签源码构建 MappedStatement 对象并记录到 Configuration 中。
每个标签解析实现由 MyBatis 提供的多个方法执行,如 XMLMapperBuilder 的 configurationElement 方法和解析具体标签的子方法,如 cacheElement、sqlElement 等。解析过程中,MyBatis 会调用不同的构造器和工厂方法来创建、初始化和配置相应的对象。 在解析完成之后,MyBatis 将所有配置对象封装在 Configuration 对象中,该对象包含所有映射文件中定义的配置信息,供后续的 SQL 语句执行和映射操作使用。Mybatis源码剖析(懒加载原理)
懒加载,即按需加载,旨在优化查询性能。以一个包含订单列表的User对象为例,当仅获取用户信息时,若启用懒加载模式,执行SQL不会查询订单列表。需获取订单列表时,才会发起数据库查询。实现方式包括在核心配置文件中设置或在相关映射文件中通过fetchType属性配置懒加载策略。
懒加载的配置如何加载到项目中呢?首先,这些配置保存在全局Configuration对象中,通常在解析核心配置文件的代码中实现。在settingsElement方法中,懒加载配置被保存在lazyLoadingEnabled属性中。对于resultMap标签中collection | association的fetchType属性,其配置通过解析mappers标签下的resultMap标签实现,最终调用buildResultMappingFromContext方法处理子标签。该方法结合全局配置判断是否需要执行懒加载。
懒加载的实现原理涉及动态代理。当调用代理对象的延迟加载属性方法时,如访问a.getB().getName(),代理对象会调用拦截器方法。若发现需要延迟加载,代理对象会单独发送SQL查询关联对象,加载数据后设置属性值,完成方法调用。简而言之,懒加载通过动态代理实现,拦截指定方法并执行数据加载。
深入剖析懒加载源码,会发现它涉及查询和数据处理的多步操作。查询完成后,结果集处理、列值获取、判断是否进行懒加载等步骤共同构建懒加载机制。动态代理在访问对象属性时触发,最终通过Javassist库创建代理对象,实现懒加载逻辑。当访问如userList2.get(0).getOrderList()时,若满足条件,代理对象会调用懒加载查询方法获取数据。判断懒加载条件的关键在于结果集处理阶段,通过访问映射关系和查询映射值来确定是否执行后续懒加载查询。
综上所述,Mybatis的懒加载机制通过动态代理和结果集处理实现,旨在优化性能,按需加载数据,提高查询效率。通过核心配置和映射文件中的配置,懒加载逻辑被加载到项目中,为开发者提供灵活的加载策略。
把Mybatis Generator生成的代码加上想要的注释
在日常开发工作中,Mybatis Generator常用于根据表结构生成实体类与Mapper文件。然而,其默认生成的代码通常缺少详细的注释,这会增加后续维护和理解代码的难度。因此,通常会配置Mybatis Generator不自动生成注释,但这样又引入了在生成代码后手动添加注释的繁琐工作。 为解决此问题,可以通过重写Mybatis Generator的CommentGenerator接口,实现自定义注释生成,减少重复劳动。以下步骤展示了如何实现这一目标。使用Java方式执行Mybatis Generator
在IntelliJ IDEA中,首先创建一个Maven项目,并在pom.xml文件中引入相关jar包。 接下来,在项目中创建generatorConfig.xml文件,通常将其放置在src/main/resources目录下。通过运行包含generatorConfig.xml的main方法,验证默认生成注释的情况,并确认其通常设置为不生成注释。 实现CommentGenerator接口,重写相关方法以自定义注释内容。修改generatorConfig.xml文件,将commentGenerator配置项替换为自定义的实现类。 运行生成器,检查生成的注释是否符合预期。使用Maven方式执行Mybatis Generator 在Pom.xml文件中增加Maven插件配置,确保在生成器依赖中引入实现CommentGenerator接口的jar包,并确保该jar包已安装到本地仓库。这样,执行Maven命令时,生成器将能够正确识别并使用自定义注释生成类。源码分析
执行Mybatis Generator的main方法,其主要功能包括解析配置文件和调用生成java文件与Mapper文件的方法。解析xml配置文件时,通过Document形式读取并解析标签属性,将解析结果存储在Configuration实例中。在生成文件时,根据Context的type属性反射创建实现CommentGenerator接口的类实例,并调用其方法生成注释。 生成实体类文件注释时,会调用addModelClassComment方法;生成字段注释时,调用addFieldComment方法;生成Get方法注释时,调用addGetterComment方法。这些方法的执行实现了自定义注释的生成。总结
通过实现自定义的CommentGenerator接口,可以轻松地将Mybatis Generator生成的代码添加上所需注释,大大减轻了手动添加注释的负担。使用Maven方式执行生成器时,需要确保引入插件依赖,并确保自定义jar包已正确安装。这种方法不仅适用于Mybatis Generator,也适用于其他使用生成器技术的开发场景。 本文由京东物流 王建乐撰写,如需转载,请注明来源:京东云开发者社区 自猿其说 Tech。