Compare Sizes
Register
English Français Español

Agile Data

3
Data Access Framework for high-latency databases (Cloud SQL/NoSQL).
PHP Data Access Libraries (ORM, ActiveRecord, Persistence)
Name
Agile Data
Sito web
git.io/ad
Github / Bitbucket / Sourceforge
git.io/ad
License
MIT
Latest version
1.2.x
How schema is defined?
in PHP. Method init() in Model class defines fields, relations, conditions, etc.
Code generation
https://github.com/atk4/schema
Can be used in Any Framework
Through composer/packagist
Automated Cache
Frameworks focuses on optimizing queries rather then caching. Still possible with cross-persistence saving.
Anti-patterns (purposely included)
Model close-coupled with Persistence and Field classes.
Audience
Dependencies
Minimal: 2 packages: DSQL Query Builder (git.io/...
Simplicity
5.0/5 2 ratings
Enterprise Compliance
5.0/5 2 ratings
Minimum PHP Version
5.6
Basic Features
PDO Support
Yes
Transparent support for NoSQL
- Through 3rd party drivers.
How to invoke db-vendor-specific extensions?
For SQL - save/load/delete operations are expressed in DSQL Queries that can be manipulated: http://git.io/dsql
Array as a persistence
CRUD operations supported
RestAPI as a persistence
- Through 3rd party extension.
JSON string as a persistence
Supported with few extra lines of code.
Same model, multiple persistences
Same class. Different object.
Basic Single-record operations (C,R,U,D)
Table Name Mapping
Yes
Field Name Mapping
Yes (Field::actual property)
Map Entity to SubQuery
Yes. Extension exist for UNION-models. https://github.com/atk4/report
Map property to expression
$model->addExpression()
Map native types (DateTime)
$field->type = 'date'
User-defined types (e.g. "23 USD")
Yes. Independent from Model. by extending Field class.
Map field of related Entity ('currency' = currency_id->Model Currency.name)
Transparently maps into sub-select.
Map field to sub-query on related entity (Client.balance = Client->orders->sum(total))
Yes. hasMany()->addField(..aggregate)
Entity to join multiple tables (adding new record populates both tables)
$model->join('other_table')
Criteria, Scope, Conditions (Model will refuse to work with records that does not match criteria)
Support model-level criteria
Yes. Applied on loading / saving / update.
Soft-delete
Through criteria. Example given in the docs.
Domain Model Criteria
$m->addCondition('gender','M'); where 'gender' can be arbitrary expression, sub-select, field from association(join) or mapped no another physical field.
Expression-based condition
$m->addCondition($m->expr('..'));
Criteria Compliance (new record must match condition)
Transaction rollback and exception. Automated-rloading.
Dynamic criteria
$user->addCondition('is_expired', false)
Query Building (Convert Model into Query object for further SQL tweaking)
Convert Model into Query Object
$q = $model->action('select');
Raw expression
new Expression('any sql')
Nested/Composite Queries/Expressions
Expression can be in any part of query
Reference domain-model field in query
through Expressionable interface
field, where, order, limit
Expressions and Parametric values
options, rollup, partition
- Through custom templates, or expressions.
UPDATE, DELETE, INSERT query building
REPLACE, TRUNCATE
SHOW, DESCRIBE, CALL
- Supported through Expressions or Custom query template
ALTER, CREATE query building
Addon: http://github.com/atk4/schema
User-defined query template
Templates for all queries
full support for OR conditions
Through Object Composition and Expressions
Use Domain logic in multi-record update
- Supported, but must map fields/values manually.
Data Fetching (different ways to retrieve data from database)
Get All Data (2x array)
Associative Array (id=>value)
No Planned
Select only required fields
Typecasting (e.g. DateTime)
Import (multiple records)
Respect domain model mapping (and criteria)
Single row
loadAny
Single Value
Through action
Single Column
- may need to map resulting array
Iterator
Bypass persistence mapping
action('select')->getAll()
Loading and Saving individual records
Load by ID
load(id)
Load by other field
loadBy('field', $value)
Read-only Models
Yes
Model without primary key
Yes, but only in Read-only Mode
Specify fields to load
onlyFields()
Save only sends dirty fields
Guarded / Fillable properties
Conditions and OnlyFields do same thing but more reliably.
Object Hierarchy Model
Admin extends User, adds criteria (is_admin=1)
Yes, recommended pattern. "User" class adds condition.
Admin extends User, adds accessible fields
Yes, recommended pattern.
Extend model, add Join (Disjoined SubTypes)
Yes. Unlimited number of joins.
Extend model change table
Yes. Used to tweak 3rd party models.
Relations/References (One model can relate to another model. NOT A TABLE JOIN)
Model can define relation to other Model
References are implemented as Objects
One-to-Many
$user->hasMany('Orders', new Order());
One-to-many traversal strategy
Returns destination model instance with dynamically applied criteria (parent_id=123). No queries are executed. Inserting record into this model will ensure association with parent model.
Lazy/Eager-loading
No Anti-pattern
One-to-One
$order->hasOne('user_id', new User());
Many-to-Many
$user->addCondition('vip', true)->ref('Orders');
Deep Many-to-Many traversal.
$user->ref('Orders')->ref('Payments')->action('count'); No intermediate queries.
Cross-Persistence traversal
$user->hasMany('Log', new Log($mongodb));
Cross-persistence joins, aggregation, reporting
Multi-persistence join
No
UNION existing models
Yes, in add-on https://github.com/atk4/report/. Can join UNION result with more tables.
Domain-model Aggregation
Group by multiple fields. Apply aggregation functions. Preserve types.
Model to Model join
No Planned.
Multi-persistence UNION
No
Behaviours / Hooks
Before/After operation
Override standard C,R,U,D operations
Persistence-specific hooks (to modify Query)
User-defined hooks
Auditing
Global Auditing
http://www.agiletoolkit.org/data/extensions/audit
Store old/new field values
Yes in JSON and user-readable string.
Revert action (undo) and replay (redo)
Reactive actions
Each action will be automatically linked with sub-actions which may be invoked through Hooks.
Store log in any persistence
Override, Add fields to audit log
Record dirty fields before persisting. Type-cast into JSON string and store in a single field of AuditLog Model. This model can be persisted anywhere, table, file, etc.
Custom events
Access to record-specific history
$item->ref('AuditLog');
Date of creation, modification
- No but easy to add through hook.
User/IP creation, modification
- Easy to add through a hook.
Store incremental revisions
- Easy to add through a hook
Integration
Field meta-information provided
Type, caption, possible values, mapped field, join table spec, encryption, serialization, UI-specific settings, validation rules.
UI extensions
CRUD, Form, Table, Grid, Entity-manager. (see https://github.com/atk4/ad)
API extensions
RestFULL API, automated CRUD operations + RPC https://github.com/atk4/api
Products
English
Public
Public
2017-12-20 01:05:19
View changes

User reviews and comments

  • Gowrav on 2016-10-25 19:16:29
    like this

    Couldn't work on any other framework/orm after switching to ATK. Its just how every programmer always wanted ...

  • Gowrav on 2016-10-25 18:51:02
    rated this Item: Enterprise Compliance 5/5

    Using in Recent modules of our ERP

  • Gowrav on 2016-10-25 18:50:37
    rated this Item: Simplicity 5/5

    Most simple among what I used (almost all popular ones)

  • Romans Malinovskis on 2016-10-24 02:18:39
    like this

    Not really an ORM, but offers much more powerful support for Domain Model.