osemk / php-custom-model
PHP CustomModel let's you to convert your MYSQL table automaticly to a PHP Model
Requires
- php: ^7.3
README
PHPCustomModel let's you to convert your MYSQL database tables to a PHP Model automaticly. This library uses mysqli to connect and to request database.
FAQ
- Can I run PHPCustomModel for all MYSQL tables?
- I tried to adopt it to use for all MYSQL tables but it can gives error with tables with non-PRI keys or tables has less identifier columns.
Getting Started
Before you start using this Library, you need to know how PHP works, you need to know how MYSQL work and what is Models. This is a fundamental requirement before you start. Without this knowledge, you will only suffer.
Requirements
Installing PHPCustomModel
PHPCustomModel is installed using Composer.
- Run
composer require osemk/php-custom-model
. This will install the latest stable release. - Include the Composer autoload file at the top of your main file:
include __DIR__.'/vendor/autoload.php';
- Make models!
Basic Example
<?php include __DIR__.'/vendor/autoload.php'; use CustomModel\CustomModel; define("VT_HOST","localhost"); // database host define("VT_ADI","databasename"); //database name define("VT_KULLANICI","databaseuser"); //databae user define("VT_SIFRE","databasepassword"); //database password $model = new CustomModel(TABLENAME,ID);
Documentation
PHPCustomModel converts tables to models. A sample database table that name is "employees"
Using PHPCustomModel we can easily convert this table to a model and we can easily do CRUD processes on table like below.
Bring table
$employee = new CustomModel("employees", 1);
This will fetch row with ID =1 and assign columns to $employee var.
We can check if has a record with ID=1,
Check records
$employee->hasRecord(); // if true id=1 founded, if false there is no record.
Now the current object includes these;
id=1, firstname=Diane, jobtitle=President
We can change these parameters using model easily like below;
Change parameters
$employee->firstname = "Angel";
$employee->jobtitle = "New President";
or
$employee->veri['firstname'] = "Angel";
$employee->veri['jobtitle'] = "New President";
and update it;
Update
$employee->update();
Now our table looks like below;
That is it!
If you want to delete record, use;
Delete
$employee->delete();
Now our table;
That is awesome!
Insert New record
Inserting a new row is also easy, just don't send an ID like below,
$employee = new CustomModel("employees",0);
It creates new model from scracth. Now you can add some strings
$employee->firstname = "Onur";
$employee->jobtitle = "King of the World";
$employee->insert();
Now our table look like below;
Other fetching methods
You can fetch directly using other columns except ids.
$employee = new CustomModel("employees",['firstname' => 'Onur']);
it directly fetches id=6 but this column is not an identifier may be there are some records too, so it fetches only latest "Onur" record.
So you can make more unique your request with adding extra columns like below;
$employee = new CustomModel("employees",['firstname' => 'Onur', 'jobtitle' => 'King of the World']);
Other easy method
The best method for this library is save() method. When you want to change or insert a record to table, you can use save().
$employee = new CustomModel("employees", 7);
$employee->firstname = "Ali";
$employee->jobtitle = "Amele";
$employee->save();
// if there is id=7 currently it updates record 7; if there is no id=7 record, it inserts automaticly to id=7.
So awesome, didn't it?
License
MIT License, © Onur Erginer 2023-present.