This ORM aims to manipulate objects from database the simpliest way
It's recommended that you use Composer to install InterventionSDK.
composer require bixev/orm "~1.0"
This will install this library and all required dependencies.
so each of your php scripts need to require composer autoload file
<?php
require 'vendor/autoload.php';
Initialise database with your own. $databaseName
is null by default. You can override it in the model classes
\Bixev\ORM\API::setDatabaseGetter(function($databaseName){
$db = new \PDO('');
return $db;
});
$databaseName
is used within the models to communicate with correct database
Get repository to manipulate objects
$exampleRepository = \Bixev\ORM\API::get('Example');
$example = $exampleRepository->createNew();
// same as
// $example = new \Bixev\ORM\Example();
$example->example_2_id = 5;
$example->name = "Tom";
$example->save();
echo $example->getId();
$id = 3;
$example = $exampleRepository->find($id);
// same as
// $example = new \Bixev\ORM\Example($id);
echo $example->name;
$db = new \PDO('');
$row = $db->query("SELECT id, name, example_2_id FROM user")->fetch();
// row has to contain all declared fields
$user = new \Bixev\ORM\Example($row);
$examples = $exampleRepository->findBy(['name' => "Tom"]);
$examples = $exampleRepository->findAll();
foreach ($examples as $example) {
echo $example->name;
}
$db = new \PDO('');
$rows = $db->query("SELECT id, name, example_2_id FROM user")->fetchAll();
// rows have to contain all declared fields
$examples = $exampleRepository->newCollection($rows);
$example = $exampleRepository->findOneBy(['name' => "Tom"]);