ActiveRecord

1 概述 

       ActiveRecord 是 JFinal 最核心的组成部分之一,通过 ActiveRecord 来操作数据库,将极大地减少代码量,极大地提升开发效率。

2 ActiveRecordPlugin 

       ActiveRecord 是作为 JFinal 的 Plugin 而存在的,所以使用时需要在 JFinalConfig 中配置ActiveRecordPlugin。以下是 Plugin 配置示例代码:

      以上代码配置了两个插件:C3p0Plugin 与 ActiveRecordPlugin,前者是 c3p0 数据源插件,后者是 ActiveRecrod 支持插件。ActiveReceord 中定义了 addMapping(String tableName, Class<? extends Model> modelClass>)方法,该方法建立了数据库表名到 Model 的映射关系。

      另外,以上代码中 arp.addMapping(“user”, User.class),表的主键名为默认为“id”,如果主键名称为 “user_id”则需要手动指定,如:arp.addMapping(“user”, “user_id”, User.class)。

 

3 Model 

      Model 是 ActiveRecord 中最重要的组件之一,它充当 MVC 模式中的 Model 部分。以下是Model 定义示例代码:             

             

      以上代码中的 User 通过继承 Model,便立即拥有的众多方便的操作数据库的方法。在 User中声明的dao静态对象是为了方便查询操作而定义的,该对象并不是必须的。基于ActiveRecord的 Model 无需定义属性,无需定义 getter、setter 方法,无需 XML 配置,无需 Annotation 配置,极大降低了代码量。

      以下为 Model 的一些常见用法: 

      特别注意:User 中定义的 public static final User dao 对象是全局共享的,只能用于数据库查询,不能用于数据承载对象。数据承载需要使用 new User().set(…)来实现。

 

4 JFinal 独创 Db + Record 模式 

      Db 类及其配套的 Record 类,提供了在 Model 类之外更为丰富的数据库操作功能。使用Db 与 Record 类时,无需对数据库表进行映射,Record 相当于一个通用的 Model。以下为 Db + Record 模式的一些常见用法:

 

       以下为事务处理示例: 

      以上两次数据库更新操作在一个事务中执行,如果执行过程中发生异常或者 invoke()方法返回 false,则自动回滚事务。

 

5 声明式事务 

      ActiveRecord 支持声名式事务,声明式事务需要使用 ActiveRecordPlugin 提供的拦截器来实现,拦截器的配置方法见 Interceptor 有关章节。以下代码是声明式事务示例:

      以上代码中,仅声明了一个 Tx 拦截器即为 action 添加了事务支持。除此之外 ActiveRecord还配备了TxByRegex、TxByActionKeys、TxByActionMethods,分别支持regex(正则)、actionKeys、actionMethods 声明式事务,以下是示例代码:

      上例中的 TxByRegex 拦截器可通过传入正则表达式对 action 进行拦截,当 actionKey 被正则匹配上将开启事务。TxByActionKeys 可以对指定的 actionKey 进行拦截并开启事务,TxByActionMethods 可以对指定的 method 进行拦截并开启事务。

      注意:MySql 数据库表必须设置为 InnoDB 引擎时才支持事务,MyISAM 并不支持事务。 

 

6 Cache 

       ActiveRecord 可以使用缓存以大大提高性能,以下代码是 Cache 使用示例: 

      上例 findByCache 方法中的 cacheName 需要在 ehcache.xml 中配置如:<cache name="cacheName" …> 。此外 Model.paginateByCache(…) 、 Db.findByCache(…) 、Db.paginateByCache(…)方法都提供了 cache 支持。在使用时,只需传入 cacheName、key 以及在 ehccache.xml 中配置相对应的 cacheName 就可以了。

 

7 Dialect 多数据库支持 

      目前 ActiveRecordPlugin 提供了 MysqlDialect、OracleDialect、AnsiSqlDialect 实现类。MysqlDialect 与 OracleDialect 分别实现对 Mysql 与 Oracle 的支持,AnsiSqlDialect 实现对遵守ANSI SQL 数据库的支持。以下是数据库 Dialect 的配置代码:

 

8 表关联操作 

      JFinal ActiveRecord 天然支持表关联操作,并不需要学习新的东西,此为无招胜有招。表关联操作主要有两种方式:一是直接使用 sql 得到关联数据;二是在 Model 中添加获取关联数据的方法。 

      假定现有两张数据库表:user、blog,并且 user 到 blog 是一对多关系,blog 表中使用 user_id关联到 user 表。如下代码演示使用第一种方式得到 user_name:

      

 

      以下代码演示第二种方式在Blog中获取相关联的 User以及在User中获取相关联的 Blog: 

 

9 Oracle 支持 

      Oracle 数据库具有一定的特殊性,JFinal 针对这些特殊性进行了一些额外的支持以方便广大的 Oracle 使用者。以下是一个完整的 Oracle 配置示例:

      由于Oracle数据库会自动将属性名(字段名)转换成大写,所以需要手动指定主键名为大写,如:arp.addMaping(“user”, “ID”, User.class)。如果想让 ActiveRecord 对属性名(字段名)的大小写不敏感可以通过设置 CaseInsensitiveContainerFactory 来达到,有了这个设置,则arp.addMaping(“user”, “ID”, User.class)不再需要了。

      另外,Oracle 并未直接支持自增主键,JFinal 为此提供了便捷的解决方案。要让 Oracle 支持自动主键主要分为两步:一是创建序列,二是在 model 中使用这个序列,具体办法如下:

      1:通过如下办法创建序列,本例中序列名为:MY_SEQ 

      CREATE SEQUENCE MY_SEQ INCREMENT BY 1 MINVALUE 1 MAXVALUE 9999999999999999 START WITH 1 CACHE 20;

      2:在 YourModel.set(…)中使用上面创建的序列 

 

      序列的使用很简单,只需要 yourModel.set(主键名, 序列名 + “.nextval”)就可以了。特别注意这里的 “.nextval” 后缀一定要是小写,OracleDialect 对该值的大小写敏感。

 

10 多数据源支持 

      ActiveRecordPlugin 可同时支持多数据源、多方言、多缓存、多事务级别等特性,对每个 ActiveRecordPlugin 可进行彼此独立的配置。简言之 JFinal 可以同时使用多数据源,并且可以针对这多个数据源配置独立的方言、缓存、事务级别等。

      当使用多数据源时,只需要对每个 ActiveRecordPlugin 指定一个 configName 即可,如下是代码示例:

      以上代码创建了创了两个 ActiveRecordPlugin 实例 arpMysql 与 arpOrace,特别注意创建实例的同时指定其 configName 分别为 mysql 与 oracle。arpMysql 与 arpOracle 分别映射了不同的Model,配置了不同的方言。

      对于 Model 的使用,不同的 Model 会自动找到其所属的 ActiveRecrodPlugin 实例以及相关配置进行数据库操作。假如希望同一个 Model 能够切换到不同的数据源上使用,也极度方便,这种用法非常适合不同数据源中的 table 拥有相同表结构的情况,开发者希望用同一个 Model来操作这些相同表结构的 table,以下是示例代码:

      上例中的代码,blog.use(“backupDatabase”)方法切换数据源到 backupDatabase 并直接将数据保存起来。

 

      特别注意:只有在同一个 Model 希望对应到多个数据源的 table 时才需要使用 use 方法,如果同一个 Model 唯一对应一个数据源的一个 table,那么数据源的切换是自动的,无需使用 use方法。

 

      对于 Db + Record 的使用,数据源的切换需要使用 Db.use(cnfigName)方法得到数据库操作对象,然后就可以进行数据库操作了,以下是代码示例:

      以上两行代码,分别通过 configName 为 mysql、oracle 得到各自的数据库操作对象,然后就可以如同单数据完全一样的方式来使用数据库操作 API 了。简言之,对于 Db + Record 来说,多数据源相比单数据源仅需多调用一下 Db.use(configName),随后的 API 使用方式完全一样。

      注意最先创建的 ActiveRecrodPlugin 实例将会成为主数据源,可以省略 configName。最先创建的 ActiveRecrodPlugin 实例中的配置将默认成为主配置,此外还可以通过设置 configName为 DbKit.MAIN_CONFIG_NAME 常量来设置主配置。

      

11 非 web 环境下使用 ActiveRecord     

      ActiveRecordPlugin 可以独立于 java web 环境运行在任何普通的 java 程序中,使用方式极度简单,相对于 web 项目只需要手动调用一下其 start() 方法即可立即使用。以下是代码示例:

      注意:ActiveRecordPlugin 所依赖的其它插件也必须手动调用一下 start()方法,如上例中的dp.start()。

 

posted @ 2016-09-19 10:52  西风.烈马  阅读(2269)  评论(0编辑  收藏  举报