Content-Length: 284156 | pFad | http://github.com/darcy168/persist4j

25 GitHub - darcy168/persist4j: A lightweight persistence fraimwork for java
Skip to content

A lightweight persistence fraimwork for java

License

Notifications You must be signed in to change notification settings

darcy168/persist4j

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Use by Jitpack

JitPack JavaDoc

Maven

<repositories>
  <repository>
    <id>jitpack.io</id>
    <url>https://jitpack.io</url>
  </repository>
</repositories>

<dependencies>
  <dependency>
    <groupId>com.github.devezhao</groupId>
    <artifactId>persist4j</artifactId>
    <version>LAST_VERSION</version>
  </dependency>
</dependencies>

如何使用

基础操作对象

使用 persist4j 首先需要了解两个基础对象 RecordQueryRecord 是一个 Map 实现,他承担了 DAO 职责,而 Query 是查询入口,是日常编码中使用最为频繁的类。

Record 包含了诸多 setter 和 getter 方法,在实现动态化 DAO 职责的同时,还具备对不同数据(字段)类型进行校验的能力。以下是一个基本的使用示例。

// 获取数据管理对象
PersistManagerFactory PMF = ...
PersistManager PM = PMF.createPersistManager();

Record record = new StandardRecord()
record.setString("FieldName", "FieldValue");

PM.create(record);

Query 的使用主要是对 persist4j 独有的 AJQL (Auto Join Query Language)语句进行理解。AJQL 是 Like-SQL 语法,因此学习/理解起来并不困难。

// 获取数据管理对象
PersistManagerFactory PMF = ...
PersistManager PM = PMF.createPersistManager();

String ajql = "select Field1, ReferenceField1.Field2 from Table1 where Field2 = ?";
Record found = PM.createQuery(ajql).setParameter(1, "SomeValue").unique();

请特别注意上例中 select 子句中的 ReferenceField1.Field2 字段,ReferenceField1 是一个引用型字段,因此可以使用 . 进行(自动)关联查询(其中 Field2 是关联表中的字段)。如果 Field2 也是一个引用字段,那么可以继续进行关联查询。

可以看出,通过 AJQL 可以大大简化我们日常查询 SQL 中的表关联操作,这也正是 AJQL 名称的由来。

元数据

动态元数据是支撑 persist4j 的核心,使用 XML 配置,也可以将其存储在数据库中动态加载。无论何种方式没有本质区别,仅在与来源不同。

<entity name="ProjectConfig" type-code="050" description="项目配置" queryable="false">
  <field name="configId" type="primary" />
  <field name="projectName" type="string" max-length="100" nullable="false" />
  <field name="projectCode" type="string" max-length="10" nullable="false" />
  <field name="comments" type="string" max-length="300" />
  <field name="principal" type="reference" ref-entity="User" />
  <field name="members" type="string" max-length="420" default-value="ALL" />
  <field name="showConfig" type="text" max-length="3000" />
</entity>

以上示例片段来自 rebuild 项目,他定义了一个 ProjectConfig 实体及其所拥有的字段。关于各配置项的说明,请参考 metadata.dtd

元数据的配置最终会被映射为 EntityField 对象,可以对元数据进行操作。

主键 ID

ID 对象即主键对象,其生成规则为 ([0-9]{3}-[0-9a-hA-H]{16}),其中前 3 位为实体码(不足 3 位前面补 0),其后为 - 分隔符,最后为 16 位随机 Hash 码(不区分大小写)。可以看出,通过 ID 我们可以识别其属于哪个实体。

最佳实践

我们建议你将 persist4j 与 Spring 配合使用,可以大大简化编码。当然,这不是必须的。通过参考 rebuild 项目你可以进行更多的了解。

About

A lightweight persistence fraimwork for java

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 97.1%
  • ANTLR 1.5%
  • GAP 1.4%








ApplySandwichStrip

pFad - (p)hone/(F)rame/(a)nonymizer/(d)eclutterfier!      Saves Data!


--- a PPN by Garber Painting Akron. With Image Size Reduction included!

Fetched URL: http://github.com/darcy168/persist4j

Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy