Skip to content

wdes/simple-php-model-system

Folders and files

NameName
Last commit message
Last commit date

Latest commit

38e67c7 · Jul 4, 2024

History

47 Commits
Jul 4, 2024
Mar 7, 2022
May 10, 2022
Jun 1, 2024
May 22, 2021
Feb 17, 2022
May 22, 2021
May 22, 2021
Jun 1, 2024
Jun 1, 2024
Feb 17, 2022
Jun 1, 2024
Jun 1, 2024
Jun 1, 2024

Repository files navigation

simple-php-model-system

Lint and analyse files Run phpunit tests codecov Version License PHP Version Require maintenance-status

A simple PHP model system

Why ?

The goal of this project is to provide an easy way to use Models in a non composer setup. This is why this project is kept very minimal. The user can copy all classes in src/ and start using the lib. But this also works in a composer setup.

How to use

Connect to an existing PDO connection

<?php
declare(strict_types = 1);

use SimplePhpModelSystem\Database;

require_once __DIR__ . DIRECTORY_SEPARATOR . 'autoload.php';// Use your autoloader or require classes by hand

$db         = new Database(null);
// With Symfony: EntityManagerInterface $em
$db->setConnection($em->getConnection()->getNativeConnection());// Wants a PDO connection object class

Connect with config

<?php
declare(strict_types = 1);

use SimplePhpModelSystem\Database;

require_once __DIR__ . DIRECTORY_SEPARATOR . 'autoload.php';// Use your autoloader or require classes by hand

$configFile = __DIR__ . DIRECTORY_SEPARATOR . 'config.php';// Copy config.dist.php and fill the values
$config     =  require $configFile;
$db         = new Database($config);
$db->connect();// Will throw an exception if not successfull

Manage models

<?php

use examples\User;

// Without models

$statement = $db->query(
    'SELECT 1'
);
$this->data = [];
while (($row = $statement->fetch(PDO::FETCH_ASSOC)) !== false) {
    $this->data[] = $row;
}
var_dump($this->data);


// With a model

$user1 = User::create(
    '5c8169b1-d6ef-4415-8c39-e1664df8b954',
    'Raven',
    'Reyes',
    null
);
$user1->save();// If you forget this line, it will only exist in memory
$user1 = User::findByUuid('5c8169b1-d6ef-4415-8c39-e1664df8b954');// Find the user back
$user1->toArray();
//[
//    'user_uuid' => '5c8169b1-d6ef-4415-8c39-e1664df8b954',
//    'first_name' => 'Raven',
//    'last_name' => 'Reyes',
//    'date_of_birth' => null,
//]
$user1->refresh(); // Get it back from the DB
$user1->setLastName('last_name', 'Ali-2');// Change an attribute value (build your own setters using the example)
$user1->update();// Update it
$user1->delete();// Delete it
User::deleteAll();// Delete all
// And more functions, see AbstractModel class