greg0 / lazer-database
PHP library to use JSON files like flat-file database
Fund package maintenance!
anant-svc
Installs: 16 073
Dependents: 8
Suggesters: 0
Security: 0
Stars: 274
Watchers: 14
Forks: 37
Open Issues: 0
Requires
- php: ^7.1 || ^8.0
Requires (Dev)
- dms/phpunit-arraysubset-asserts: ^0.4.0
- mikey179/vfsstream: ^1.6
- phpunit/phpunit: ^7.0 || ^8.0
- yoast/phpunit-polyfills: ^1.0
- dev-master
- 2.0.2
- 2.0.1
- 2.0.0
- 1.2.0
- 1.1.9
- 1.1.8
- 1.1.7
- 1.1.6
- 1.1.5
- 1.1.4
- 1.1.3
- 1.1.2
- 1.1.1
- 1.1
- 1.0.14
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- dev-anant-svc-upcomming
- dev-migrate-to-github-actions
- dev-feature/php-7
- dev-master_clone
- dev-bugfix/anant-svc-mikey179-vfsstream
- dev-hotfix/type-double-validation
- dev-feature/type-array-in-set
- dev-hotfix/accept-null-data-error
- dev-special-char-issue
- dev-new-feature-to-save
- dev-build
This package is auto-updated.
Last update: 2024-10-28 18:44:36 UTC
README
PHP Library to use JSON files like a database.
Functionality inspired by ORM's
Requirements
- PHP 7.1+
- Composer
Installation
Easiest way to install Lazer Database
is to use Composer. Of course you can use your own autoloader but you must configure it properly by yourself. You can find my Package on Packagist.org.
To add library to your dependencies, execute:
composer require greg0/lazer-database
Tests
Easiest way to run unit tests is to use composer script
composer run test
You can also use docker
docker build -t lazer-db .
docker run -it --rm lazer-db
Structure of table files
table_name.data.json
- table file with data
table_name.config.json
- table file with configuration
Basic Usage
First of all you should define constant LAZER_DATA_PATH
containing absolute path to folder with JSON files:
define('LAZER_DATA_PATH', realpath(__DIR__).'/data/'); //Path to folder with tables
Then set up namespace:
use Lazer\Classes\Database as Lazer; // example
Methods
Chain methods
setField()
- set value of field (alternative to magic__set()
)limit()
- returns results between a certain number range. Should be used right before ending methodfindAll()
.orderBy()
- sort rows by key in order, can order by more than one field (just chain it).groupBy()
- group rows by field.where()
- filter records. Alias:and_where()
.orWhere()
- other type of filtering results.with()
- join other tables by defined relations
Ending methods
getField
- get value of field (alternative to magic__get()
)issetField
- check if field is isset (alternative to magic__isset()
)addFields()
- append new fields into existing tabledeleteFields()
- removing fields from existing tableset()
- get key/value pair array argument to save.save()
- insert or Update data (automatically detect if it needs an insert or update).insert()
- force an insert.delete()
- deleting data.relations()
- returns array with table relationsconfig()
- returns object with configuration.fields()
- returns array with fields name.schema()
- returns assoc array with fields name and fields typefield => type
.lastId()
- returns last ID from table.find()
- returns one row with specified ID.findAll()
- returns rows.asArray()
- returns data as indexed or assoc array:['field_name' => 'field_name']
. Should be used after ending methodfindAll()
orfind()
.count()
- returns the number of rows. Should be used after ending methodfindAll()
orfind()
.
Create database
Lazer::create('table_name', array( 'id' => 'integer', 'nickname' => 'string', {field_name} => {field_type} ));
More information about field types and usage in PHPDoc
Remove database
Lazer::remove('table_name');
Check if a database exists
try{ \Lazer\Classes\Helpers\Validate::table('table_name')->exists(); } catch(\Lazer\Classes\LazerException $e){ //Database doesn't exist }
Select
Multiple select
$table = Lazer::table('table_name')->findAll(); foreach($table as $row) { print_r($row); }
Single record select
$row = Lazer::table('table_name')->find(1); echo $row->id; // or $row->getField('id')
Type ID of row in find()
method.
You also can do something like that to get first matching record:
$row = Lazer::table('table_name')->where('name', '=', 'John')->find(); echo $row->id;
Insert
$row = Lazer::table('table_name'); $row->nickname = 'new_user'; // or $row->setField('nickname', 'new_user') $row->save();
Do not set the ID.
Update
It's very smilar to Inserting
.
$row = Lazer::table('table_name')->find(1); //Edit row with ID 1 $row->nickname = 'edited_user'; // or $row->setField('nickname', 'edited_user') $row->save();
You can also set many field by simple key-value array
$row = Lazer::table('table_name')->find(1); //Edit row with ID 1 $row->set(array( 'nickname' => 'user', 'email' => 'user@example.com' )); $row->save();
Remove
Single record deleting
Lazer::table('table_name')->find(1)->delete(); //Will remove row with ID 1 // OR Lazer::table('table_name')->where('name', '=', 'John')->find()->delete(); //Will remove John from DB
Multiple records deleting
Lazer::table('table_name')->where('nickname', '=', 'edited_user')->delete();
Clear table
Lazer::table('table_name')->delete();
Relations
To work with relations use class Relation
use Lazer\Classes\Relation; // example
Relation types
belongsTo
- relation many to onehasMany
- relation one to manyhasAndBelongsToMany
- relation many to many
Methods
Chain methods
belongsTo()
- set relation belongsTohasMany()
- set relation hasManyhasAndBelongsToMany()
- set relation hasAndBelongsToManylocalKey()
- set relation local keyforeignKey()
- set relation foreign keywith()
- allow to work on existing relation
Ending methods
setRelation()
- creating specified relationremoveRelation()
- remove relationgetRelation()
- return informations about relationgetJunction()
- return name of junction table inhasAndBelongsToMany
relation
Create relation
Relation::table('table1')->belongsTo('table2')->localKey('table2_id')->foreignKey('id')->setRelation(); Relation::table('table2')->hasMany('table1')->localKey('id')->foreignKey('table2_id')->setRelation(); Relation::table('table2')->hasAndBelongsToMany('table1')->localKey('id')->foreignKey('id')->setRelation(); // Junction table will be crete automaticly
Remove relation
Relation::table('table1')->with('table2')->removeRelation();
Get relation information
You can do it by two ways. Use Standard Database class or Relation but results will be different.
Relation::table('table1')->with('table2')->getRelation(); // relation with specified table Lazer::table('table1')->relations(); // all relations Lazer::table('table1')->relations('table2'); // relation with specified table
Description
For some examples please check Examples and Tutorial file. More informations you can find in PHPDoc, I think it's documented very well.
E-mail: gerg0sz92@gmail.com
If you like and using/want to use my repo or you have any suggestions I will be greatful for sending me few words on e-mail.