皮皮网
皮皮网

【休眠 源码】【boot源码带注解】【测算2023年源码】mybatis源码反射

时间:2025-01-07 22:54:49 来源:源码论坛编制进度

1.如何使用Java反射来获取MyBatis中的码反SQL语句?
2.java通过反射拿到mybatis中的sql语句并操作怎么用什么时候用?
3.通过方法引用获取属性名的底层逻辑是什么?
4.mybatis的反射工具类—MetaObject(反射对象类)
5.mybatis @SelectProvider 注解, 打赌你没有用过

mybatis源码反射

如何使用Java反射来获取MyBatis中的SQL语句?

       使用Java反射来获取MyBatis中的SQL语句并进行操作的需求并不常见。通常,码反MyBatis会处理SQL语句的码反执行和结果映射。然而,码反如果您确实有这样的码反需求,可以使用以下方法来实现。码反休眠 源码

       首先,码反您需要从MyBatis的码反映射器接口(Mapper接口)中获取SQL语句。这里我们假设您已经定义了一个映射器接口和相应的码反XML映射文件。例如,码反UserMapper接口和对应的码反UserMapper.xml文件。

       在MyBatis的码反配置文件(例如:mybatis-config.xml)中,启用映射器接口的码反mapperLocations属性,以便MyBatis可以找到XML映射文件:

xml

       使用反射API,码反从映射器接口获取SQL语句。码反下面的示例代码展示了如何从UserMapper接口获取名为selectUser的SQL语句:

       import org.apache.ibatis.io.Resources;

       import org.apache.ibatis.session.SqlSessionFactory;

       import org.apache.ibatis.session.SqlSessionFactoryBuilder;

       import java.io.InputStream;

       public class MyBatisSqlReflectionDemo {

       public static void main(String[] args) throws Exception {

       String resource = "path/to/your/mybatis-config.xml";

       InputStream inputStream = Resources.getResourceAsStream(resource);

       SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

       // 获取 UserMapper 映射器接口的代理实例

       UserMapper userMapper = sqlSessionFactory.openSession().getMapper(UserMapper.class);

       // 获取 UserMapper 中名为 selectUser 的方法

       Method selectUserMethod = UserMapper.class.getDeclaredMethod("selectUser", Integer.class);

       // 获取 selectUser 方法上的 @Select 注解

       Select selectAnnotation = selectUserMethod.getAnnotation(Select.class);

       // 获取 @Select 注解中的 SQL 语句

       String sql = selectAnnotation.value()[0];

       System.out.println("SQL 语句: " + sql);

       }

       }

       请注意,这个方法只适用于使用注解配置的boot源码带注解MyBatis映射器。如果您使用XML映射文件,您需要解析XML文件并查找相应的SQL语句。

       获取SQL语句后,您可以根据需求对其进行操作。然而,直接操作SQL语句可能会导致一些问题,例如SQL注入、难以维护等。因此,请谨慎考虑是否确实需要这样做。

       通常情况下,我们不建议使用反射来操作MyBatis中的SQL语句。相反,您应该利用MyBatis的动态SQL功能或在映射器接口中定义多个方法来处理不同的需求。这样可以确保代码的可维护性和安全性。

java通过反射拿到mybatis中的测算2023年源码sql语句并操作怎么用什么时候用?

       操作。具体的步骤如下:

       获取 MyBatis 中的 MappedStatement 对象。可以通过 SqlSession 的 getConfiguration() 方法获取 Configuration 对象,然后再通过 Configuration 对象的 getMappedStatement() 方法获取 MappedStatement 对象。

       从 MappedStatement 对象中获取 BoundSql 对象,即 SQL 语句绑定的参数对象。

       从 BoundSql 对象中获取 SQL 语句字符串。可以通过调用 getSql() 方法获取 SQL 语句字符串。

       对 SQL 语句进行相应的操作。例如,可以对 SQL 语句进行修改、输出等操作。

       Java 通过反射获取 MyBatis 中的 SQL 语句的代码示例:

       SqlSession sqlSession = sqlSessionFactory.openSession();

       try {

       // 获取 MappedStatement 对象

       MappedStatement mappedStatement = sqlSession.getConfiguration().getMappedStatement("com.example.mapper.selectUser");

       // 获取 BoundSql 对象

       BoundSql boundSql = mappedStatement.getBoundSql(paramObject);

       // 获取 SQL 语句字符串

       String sql = boundSql.getSql();

       // 对 SQL 语句进行相应的操作

       // ...

       } finally {

       sqlSession.close();

       }

       需要注意的是,在使用反射获取 SQL 语句时,要注意保护用户隐私和安全,以免发生 SQL 注入等问题。

通过方法引用获取属性名的玛丽冒险源码讲解底层逻辑是什么?

       很多小伙伴可能都用过 MyBatis-Plus,这里边我们构造 where 条件的时候,可以直接通过方法引用的方式去指定属性名:Book::getId。这里边的底层逻辑是什么?

       源码分析中,通过 qw.eq 这个方法的执行,几经辗转来到 getColumnCache 方法,这个方法解析出属性值。首先,通过 LambdaUtils.extract 方法解析出一个 LambdaMeta 对象,重点在于反射读取,找到名为 writeReplace 的方法并执行,将执行结果封装为 ReflectLambdaMeta 对象返回。

       接着,在 getColumnCache 方法中,通过 String fieldName = PropertyNamer.methodToProperty(meta.getImplMethodName()) 获取到属性名称。meta.getImplMethodName() 获取到的是 Lambda 表达式中的方法名,如 getId,hfs商城源码配置然后通过 PropertyNamer.methodToProperty 对其进行处理,最终拿到属性名。解析过程是去掉方法名的前缀(get/set/is)后,剩余的字符串首字母小写。

       理解 writeReplace 方法是系统底层自动生成的,通过反编译运行时生成的字节码,可以看到 apply 方法实际上是重写的接口方法,将传入的对象强转为 Book 类型,调用其 getId 方法。反编译后,多了一个 writeReplace 方法,返回值是 SerializedLambda 对象,这个对象描述了 Lambda 表达式,implMethodName 参数就是方法名。

       总结,使用 Book::getId 能拿到 id 这个名称,关键在于利用 Lambda 在执行时生成的字节码去获取属性名称。使用 SFunction 实例或者不使用方法引用都是不对的,会报错或无法获取到属性名称。通过底层的差异,我们可以理解到类似于 b -> b.getId() 的 Lambda 与方法引用在底层原理上的不同。最后,分享一些扩展知识和推荐工具,如 JNPF 快速开发平台,它集成了代码生成器,支持前后端业务代码生成,方便快速开发。

mybatis的反射工具类—MetaObject(反射对象类)

        MeatObject是Mybatis的工具类,通过MetaObject获取和设置对象的属性值。

        返回结果:

        基本的pojo对象:

        MetaObject提供了一个工具类:

        当调用 SystemMetaObject 获取 MetaObject 对象时,每次均 new DefaultReflectorFactory() 了一个反射工厂类。

        继续查看:

        这个类并没有做很复杂的操作,就是获取object的type类型,且存储到Map中。当同一个object调用 forObject() 时,后续调用可以在缓存中获取反射对象。

        但注意: SystemMetaObject 方法因为每次均new了一个新的 DefaultReflectorFactory 工厂。若每次在方法中调用 SystemMetaObject.forObject 获取 MetaObject 对象。同一个对象可能不会走缓存。

        推荐做法:将 DefaultReflectorFactory 声明为静态变量:

        在创建 MetaObject 对象的时候,就会将传入的Object对象的所有反射对象都缓存起来。后续调用 metaObject.setValue 等方法时,直接在缓存中获取到反射对象,然后执行反射操作。

        创建MetaObject对象时,选择不同的Wrapper进行包装。

        以普通的pojo为例,创建 BeanWrapper 对象,在 forClass 方法中会遍历object的所有方法。获取反射对象。

        到此处:

        到达此处,判断缓存中是否存在某对象的解析结果:

        注意: MetaObject.forObject 会将object结果缓存起来,后续在使用MetaObject.forObject创建对象时,直接在缓存中获取。

        若没有存在,则调用 new Reflector(type); 去创建cache对象。

        总方法:

        2. 删除方法的前缀,获取属性名:

        3. key为属性名,value是集合:

        4. 将局部变量放入到属性集合中:

        5. 放入到属性变量中

        设置分词器:

        blogs.com/javadeveloper/archive////.html

mybatis @SelectProvider 注解, 打赌你没有用过

       在探索MyBatis框架时,不期而遇了四个注解,它们分别是@SelectProvider、@InsertProvider、@UpdateProvider以及@DeleteProvider。这四个注解,各自在MyBatis的增删改查操作中扮演着另类角色,将传统的XML配置方式转化为注解驱动,为开发者提供了一种更为灵活、简洁的SQL编写途径。

       深入了解@SelectProvider注解时,发现其包含了两个属性,这两个属性均无默认值,这暗示了使用@SelectProvider时,这两者必须配合使用。尽管未深入探究源码解析,但可以推测,通过反射获取方法的返回值是其核心机制。

       在实战应用中,使用@SelectProvider时,首先需要定义一个Mapper接口,其中会用到@Param注解,以确保参数在调用指定方法时能够被正确映射为Map。然后,创建与类型对应的SQL语句类,并定义生成SQL语句的方法。这一过程中的关键点在于理解,SQL类作为MyBatis提供的工具类,允许开发者在代码中灵活编写SQL语句。

       思考@SelectProvider与@Select注解之间的异同,会发现二者在定义方式上有所区别:@Select直接定义SQL,而@SelectProvider则在外部定义SQL并直接引用。但这两种方式在实际功能上并无本质区别。在MyBatis初始化时,通过不同的逻辑组装SqlSource,分别对应这两种定义方式。

       在编写SQL时,MyBatis提供了多种选择,包括@Select、@SelectProvider和XML文件三种形式,分别针对不同场景提供支持。@Select适合简单场景,提供最简洁的SQL定义方式,省去了编写XML文件的繁琐步骤。@SelectProvider则适用于编写中等长度、简单查询场景,借助SQL工具类提供了便捷的API语法。若不使用工具类,开发者亦可手动编写SQL字符串。XML文件形式则功能全面,支持计算函数、动态SQL和各种关键字,适合需要高度定制化SQL的复杂场景。

       总结而言,MyBatis通过提供丰富的注解和配置选项,使得SQL编写更为灵活和高效。通过良好的变量和方法命名,增强代码的可读性和维护性。对于源码阅读的习惯,欢迎分享和讨论,共同探索更好的学习路径。

更多内容请点击【百科】专栏