第三章 Mybatis 常用工具

 ScriptRunner SqlRunner

ScriptRunner 和 SqlRunner 这两个术语通常不是特定于某个数据库或编程语言的内置工具或类,但它们描述了一类在软件开发中常用的工具或库的功能,这些工具或库用于执行SQL脚本或查询。这些工具可以大大简化数据库管理、数据迁移、测试以及自动化任务中的数据库交互。

ScriptRunner

ScriptRunner 通常指的是一个能够执行SQL脚本文件的工具或库。这些脚本文件可能包含了一系列的SQL语句,用于创建数据库、表、索引,插入数据,更新数据,删除数据等。ScriptRunner 工具能够读取这些脚本文件,并逐条执行其中的SQL语句。

  • 用途:数据库初始化、数据迁移、测试数据准备等。
  • 实现:不同的编程语言或数据库管理工具可能有自己的 ScriptRunner 实现。例如,在Java中,Apache Commons DBUtils库提供了一个ScriptUtils类,它可以用来执行SQL脚本文件。
  • 特点:支持事务处理、错误处理、日志记录等。

SqlRunner

SqlRunner 则更侧重于执行单个SQL查询或命令,而不是整个脚本文件。它可能是一个命令行工具、图形界面工具或编程库中的一个组件,允许用户或开发者直接输入SQL语句并立即执行。

  • 用途:快速查询、调试、数据验证等。
  • 实现:大多数数据库管理系统(DBMS)都提供了自己的 SqlRunner 形式的工具,如MySQL的命令行客户端、PostgreSQL的psql工具等。此外,许多编程语言也提供了执行SQL查询的库或框架,如Python的SQLAlchemy、JDBC(Java数据库连接)等。
  • 特点:即时反馈、支持参数化查询、易于集成到自动化脚本中。

MetaObject MetaClass

在 MyBatis 3 中,MetaObject 和 MetaClass 是与对象反射操作相关的两个关键概念,它们主要用于在 MyBatis 框架内部处理对象的属性访问和修改,特别是在动态 SQL 和结果集映射(Result Map)的上下文中。不过,值得注意的是,在 MyBatis 3 的官方文档和源代码中,MetaClass 这个术语并不直接出现作为一个类名,但我们可以从 MetaObject 的使用中理解到类似 MetaClass 功能的实现。

MetaObject

MetaObject 是 MyBatis 提供的一个接口,它封装了对象的属性操作,如获取属性值、设置属性值等。这个接口提供了一种更高级的方式来操作对象的属性,而不需要直接调用 Java 反射 API。这样做的好处是可以减少直接使用反射带来的性能开销,并且可以更容易地集成到 MyBatis 的整体架构中。

在 MyBatis 中,MetaObject 主要用于:

  1. 动态 SQL:在构建 SQL 语句时,可能需要根据对象的属性值来决定 SQL 的具体形式。通过 MetaObject,MyBatis 可以方便地访问这些属性值。
  2. 结果集映射:当从数据库查询结果并映射到 Java 对象时,MyBatis 使用 MetaObject 来设置对象的属性值。

MetaClass(概念性)

虽然 MyBatis 3 没有直接提供一个名为 MetaClass 的类,但我们可以将 MetaObject 视为是对某个 Java 类(Class)的元信息(Meta Information)的封装,这个元信息包括了类的属性、方法等。在 MyBatis 内部,对于每个被操作的 Java 对象,都会创建一个对应的 MetaObject 实例来封装该对象的元信息和操作。

因此,可以说 MyBatis 通过 MetaObject 间接实现了类似 MetaClass 的功能,即提供了一种机制来访问和操作 Java 对象的元信息和属性。

实现细节

在 MyBatis 的实现中,MetaObject 接口通常由 DefaultMetaObject 类来实现。这个类通过包装一个 Java 对象(通常是一个 POJO)和一个 SystemMetaObjectHandler(用于处理特殊类型或情况的处理器),来提供对对象属性的访问和修改功能。

MetaObject 还支持链式调用和属性路径解析,使得在复杂对象图中访问深层属性变得简单。

总结

在 MyBatis 3 中,MetaObject 是处理对象属性访问和修改的核心接口,而 MetaClass 虽然不是直接存在的类,但我们可以将 MetaObject 视为对 Java 类元信息的封装,从而理解 MyBatis 是如何以高级和灵活的方式处理对象属性的。

 ObjectFactory ProxyFactory

在 MyBatis 3 中,ObjectFactory 和 ProxyFactory 是两个关键的接口,它们在 MyBatis 的内部机制中扮演着重要的角色。这些接口和它们的实现类共同协作,以支持 MyBatis 的高级功能,如对象创建、动态代理等。

ObjectFactory

ObjectFactory 接口是 MyBatis 用来创建对象实例的工厂接口。在 MyBatis 中,当需要实例化一个对象(比如执行结果映射到 POJO)时,MyBatis 会使用 ObjectFactory 来完成这一任务。默认情况下,MyBatis 使用 DefaultObjectFactory,它基于 Java 的 newInstance() 方法或者构造函数来创建对象实例。

但是,你可以通过配置自定义的 ObjectFactory 来改变对象的创建方式。例如,你可以使用自定义的 ObjectFactory 来实现依赖注入、单例模式等高级功能。

ProxyFactory

ProxyFactory 接口是 MyBatis 用来创建动态代理对象的工厂接口。在 MyBatis 中,动态代理通常用于实现 Mapper 接口的动态代理,这样开发者就可以直接调用 Mapper 接口的方法来执行 SQL 语句,而不需要编写具体的实现代码。

MyBatis 提供了多种 ProxyFactory 的实现,其中最常用的是基于 JDK 动态代理的 JdkDynamicAopProxy 和基于 CGLIB 的 CglibProxyFactory。默认情况下,MyBatis 会根据 JVM 的版本和配置选择最合适的 ProxyFactory 实现。

自定义实现

虽然 MyBatis 提供了默认的 ObjectFactory 和 ProxyFactory 实现,但在某些情况下,你可能需要自定义这些工厂的行为。例如,你可能需要在创建对象时执行一些额外的逻辑,或者你需要使用不同的动态代理实现来满足特定的需求。

在 MyBatis 的配置文件中,你可以通过 <objectFactory> 和 <proxyFactory> 标签来指定自定义的 ObjectFactory 和 ProxyFactory 实现。然后,MyBatis 会在运行时使用这些自定义实现来创建对象和动态代理。

总结

ObjectFactory 和 ProxyFactory 是 MyBatis 中用于对象创建和动态代理的关键接口。通过自定义这些接口的实现,你可以扩展 MyBatis 的功能,以满足特定的需求。在大多数情况下,MyBatis 的默认实现已经足够使用,但在需要更高级功能时,自定义实现将是一个很好的选择。

 

一. 生成器模板路径可以引用相关变量 如 ${basepackage}/${className}.java,根据该变量生成输出文件 二. 自动搜索某个目录所有模板文件,无需配置 三.代码生成器模板可以引用的相关变量 1. g.generateByTable("table_name") 方法可以引用的变量 table : cn.org.rapid_framework.generator.provider.db.table.model.Table 2. g.generateByClass(UserInfo.class) 方法可以引用的变量 clazz : cn.org.rapid_framework.generator.provider.java.model.JavaClass 3. g.generateBySql("select * from user_info where pwd=:pwd") 方法可以引用的变量 sql : cn.org.rapid_framework.generator.provider.db.sql.model.Sql 4.公共变量 env : 系统环境变量 System.getProperties() : 直接引用,没有前缀 generator.properties 文件中的所有属性,直接引用,没有前缀 gg : 模板控制变量, cn.org.rapid_framework.generator.GeneratorControl 四.每个模板有gg变量可以控制自身的自定义配置 (每一个模板都会创建新的gg实例) 如是否生成,是否覆盖目标文件,甚至是生成其它文件 ${gg.setIgnoreOutput(true)}: 如果为true则不生成输出文件 ${gg.generateFile(outputFile,content)} 在模板中生成其它文件 ${gg.getProperty(key,defaultValue)}: 得到proproty,如果没有找到,则返回默认值 ${gg.getInputProperty(key)}: 会弹出一个输入框,提示用户输入值 具体参考: http://code.google.com/p/rapid-framework/wiki/rapid_generator_gg 五.支持生成(gen)及删除操作(del),即生成的代码也可以很方便的删除 六. 自动删除模板扩展名: .ftl,.vm 举例: 如你有一个模板 SqlMap.xml.ftl 将变为 SqlMap.xml 所以你要生成ftl扩展名的文件,应该将文件名从 list.ftl => list.ftl.ftl 七. 模板自动include所有父目录的:macro.include文件,可以存放公共的macro 示例: 如你的模板为 com/project/UserDao.java, 将自动include: com/project/macro.include, com/macro.include, macro.include 八. generator.xml (或者generator.properties)配置文件 1.类似ant可以变量引用,引用环境变量使用${env.JAVA_HOME}, 引用System.getProperties()直接引用 2.自动替换generator.properties中的句号(.)为反斜杠,设置key为key+"_dir"后缀 示例: pkg=com.company => pkg_dir=com/company 九.自动拷贝二进制文件至输出目录 如模板目录下的 zip,rar,doc文件将会自动拷贝至输出目录,不会破坏文件格式 (通过扩展名自动识别) 十. 数据库表配置,用于自定义生成器模板引用的table变量,配置文件必须存放在classpath: generator_config/table/table_name.xml (该文件生成器可以生成,自己再自定义修改)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值