This package is abandoned and no longer maintained. The author suggests using the lightning/model package instead.

Light & fast PHP ORM, using Hydrahon (query builder), Carbon (DateTime extension) and Eloquent's Collection component (Laravel).

0.5.0 2025-01-06 16:48 UTC

This package is auto-updated.

Last update: 2025-01-06 17:06:05 UTC


README

Lightning ORM is an Object Relational Mapper written in PHP.

Latest Stable Version Total Downloads License Build Status Code Coverage Scrutinizer Code Quality

Why reinventing the wheel ?

I like the Laravel/Eloquent syntax and philosophy, but the performances are very poor when requesting relations from a collection (example : $customers->orders) because it makes one query per customer... Lightning ORM makes a single request and hydrates all the entities at once.

I also have the habbit of prefixing all my fields with the table's name to make them unique (examples : customer.cst_id, order.rdr_id, order.rdr_cst_id). This allows to make requests without using the tables names : SELECT * FROM order JOIN customer ON cst_id = rdr_cst_id. Lightning ORM handles this natively.

Installation

Lightning ORM follows PSR-4 autoloading and can be installed using composer:

$ composer require 'lightning/orm'

Running tests

The root user should be able to connect to MySQL without any password.
You should also run those two commands to install the dependencies and the test database :

$ composer install
$ tests/bin/init.sh

After that, you can run the tests using Composer :

$ composer test

Quick Start

Not written yet...

Dependencies

Lightning ORM is using :

  • Hydrahon (query builder)
  • Carbon (DateTime extension)
  • The Collection component from Laravel/Eloquent

License

The MIT License (MIT). Please see License File for more information.