1. Go to this page and download the library: Download thomasjbradley/micromodel library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
thomasjbradley / micromodel example snippets
class Planets extends MicroModel
{
public function defineSchema ()
{
// Define all the table's fields
}
}
$app = new Silex\Application();
$planets = new Planets($app);
$planetsList = $planets->all();
use Symfony\Component\Validator\Constraints as Assert;
class Planets extends MicroModel
{
public function defineSchema ()
{
// The primary key MUST always come first
$this->defineField('id', 'integer');
$this->defineField('name', 'text', array(
'constraints' => array(new Assert\NotBlank())
, 'set' => function ($val) {
return filter_var($val, FILTER_SANITIZE_STRING);
}
));
$this->defineField('orbital_period', 'number', array(
'constraints' => array(new Assert\Number())
, 'precision' => 2
, 'set' => function ($val) {
return filter_var($val, FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION);
}
));
$this->defineField('last_updated', 'date', array(
'constraints' => array(new Assert\NotBlank(), new Assert\Date())
, 'format' => 'yyyy-MM-dd'
, 'display' => false
, 'set' => function ($val) {
if (is_object($val)) return $val;
return new DateTime($val);
}
));
}
}
$planets = new Planets($app, 1);
echo $planets->name; // Mercury
$planets = new Planets($app);
$planetsList = $planets->find();
foreach ($planetsList as $planet) {
echo $planet->name;
}
// Since each item in the array is your model object, you could do this
$planetsList[0]->name = 'Neptune';
$planetsList[0]->update();
// Using the $order argument
$planets->find('name ASC');
$planets->find(array('name ASC', 'orbital_period DESC'));
// Using the $where argument
$planets->find(null, array(
array('orbital_period', '>', 200)
, array('name', 'LIKE', '%e%')
));
// Using $order and $where
$planets->find('name ASC', array(
array('orbital_period', '>', 200)
));
$planets = new Planets($app);
$planets->name = 'Jupiter';
$planets->orbital_period = 4332.59;
$planets->last_updated = new DateTime();
$planets->create();
echo $planets->id; // 4
$planets = new Planets($app);
// Use the primary key to select an item
// Equates to WHERE id = 1
$planet = $planets->read(1);
echo $planet->name; // Mercury
// Set up a WHERE clause with arrays
// Equates to WHERE name = 'Earth'
$planet = $planets->read(array(
array('name', '=', 'Earth')
));
echo $planet->name; // Earth
$planets = new Planets($app, 2);
$planets->last_updated = new DateTime();
$planets->update();
$planets = new Planets($app, 3);
$planets->delete();
$planets = new Planets($app, 1);
$form = $planets->getForm();
// $form->bind($request);
// $form->isValid();
// $form->createView();
// When writing a JSON API
$form = $planets->getForm(false);
// Symfony's form bind() method expects an array, so force json_decode to use associative arrays
$form->bind(json_decode($request->getContent(), true));
if ($form->isValid()) {
$movie->create();
$app->abort(204);
}
$planets = new Planets($app, 2);
// PHP/5.4
return $app->json($planets);
// PHP/5.3
return $app->json($planets->jsonSerialize());
// Because PHP/5.3 doesn't have the JsonSerializer interface
// Will work equally as well in PHP/5.4
$planets = new Planets($app);
$planets->name = 'Saturn';
$planets->orbital_period = 10759.22;
$planets->last_updated = new DateTime();
$planets->isValid(); // true
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.