joaojkuligowski/mypersist

A very simple persistence layer for PHP Projects

Installs: 9

Dependents: 0

Suggesters: 0

Security: 0

Stars: 3

Watchers: 2

Forks: 0

Open Issues: 0

pkg:composer/joaojkuligowski/mypersist

v1.0.0 2024-10-17 15:58 UTC

This package is not auto-updated.

Last update: 2025-10-17 19:58:21 UTC


README

MyPersist is a lightweight micro ORM (Object-Relational Mapping) for PHP that supports both PDO (for database interaction) and JSON files (for lightweight data storage). This library allows you to easily create, read, update, and delete data while maintaining a clean and simple codebase.

Features

  • Support for SQLite databases using PDO.
  • Option to use JSON files for data storage.
  • Automatic table creation and column management.
  • Upsert functionality to handle both inserts and updates.
  • Simple API for interacting with your data.

Installation

You can install MyPersist via Composer.

composer require joaojkuligowski/mypersist

Usage

Setup

First, create a new instance of the Base class. You can choose the storage driver (PDO or JSON).

Using PDO (SQLite)

use Joaojkuligowski\Mypersist\Base;

$persistBase = new Base('PDO', 'sqlite:base.db');

Using JSON

use Joaojkuligowski\Mypersist\Base;

$persistBase = new Base('JSON', 'file.json');

Basic Operations

Inserting Data

To insert data into a table, use the insert method:

$data = [
    'name' => 'John Doe',
    'email' => 'john.doe@example.com',
];

$persistBase->insert('users', $data);

Selecting Data

To retrieve data from a table, use the select method:

$users = $persistBase->select('users', ['email' => 'john.doe@example.com']);
print_r($users);

Upserting Data

To insert or update a record, use the upsert method. This is particularly useful for maintaining unique records:

$data = [
    'email' => 'john.doe@example.com',
    'name' => 'Johnathan Doe', // Update name if email already exists
];

$persistBase->upsert('users', $data, 'email'); // 'email' is the unique key

Working with joins

To join data, use the join method:

$table1 = 'users' ;
$table2 = 'invoices' ;
$joinColumnTable1 = 'code' ;
$joinColumnTable2 = 'userCode' ;

$persistBase->join($table1, $table2, $joinColumnTable1, $joinColumnTable2);

Docs

Complete Documentation

Table and Column Management

The library automatically creates tables and columns as needed. If you insert data into a table that doesn’t exist, it will be created with the appropriate columns.

Error Handling

All methods include basic error handling. If an error occurs during database operations, it will output an error message. You can further enhance error handling based on your requirements.

Running Tests

You can run the tests using PHPUnit. First, ensure you have PHPUnit installed, then execute:

./vendor/bin/phpunit tests

Contributing

If you'd like to contribute to MyPersist, feel free to fork the repository and submit a pull request. Ensure you follow the coding standards and include tests for any new features or bug fixes.

License

This project is licensed under the MIT License. See the LICENSE file for details.