Skip to content

open-crud is an open-source package created in native PHP that simplifies connecting to MySQL databases and makes it easier to manage databases using object-oriented programming.

Notifications You must be signed in to change notification settings

ElieRu/open-crud

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Overview


open-crud is an open-source package created in native PHP that simplifies connecting to MySQL databases and makes it easier to manage databases using object-oriented programming.

Some challenges :

  • How to connect my app to the database?
  • How to make CRUD easier to use?

In this documentation, we want to explain you how OpenCRUD package can be connected to your application and use different operations to manage your datas from a mySql database.

Installation


  1. Requirements
  • Be sure to have a PHP version that is up to date.
  • You might know object-oriented programming, or you might not.
  1. Connection
  • Download and insert the package in your project.

  • Create the mySQL database.

  • Initialise your database informations in the /database/db-infos.php file.

  • Link the init.php in the file that you need to instantiate OpenCRUD.

    Note : By default, you need to initialise the $dbname variable only.

    MySql rules : Your table's attributes will have the null value by default. Except the primary key.

  1. Instanciation

To interact with databases using OpenCrud, you create an object instance. This object acts as a representation of one or more database tables, and it provides methods for performing CRUD operations (Create, Read, Update, and Delete) on the table data.

# I instantiate the users table
$users = new Crud($users, $attributes, $type);

The required params :

  • array $tables is specify the table(s) that we need to use.
  • array $attributes will have access to the table's attributes and to the foreigner key(s) also if necessary.
  • bool $type return a row of values in case of false value. Else, it returns a row of objects values.

Getting started

Create

The create operation allow you to save datas by calling the create method of the instantiated object.

# The save a data
$users->create($formData);

The create method requires an array of data to be saved, excluding the primary key. However, it accepts foreign keys for establishing relationships with other data entities.

Read

The read operation retrieves datas from the database and display them to the user interface. The read operation can handle different parameters as needed. To improve code organization and readability, it's recommended to assign the read method to a variable.

# I get datas
$getDatas = $users->read($fields, $condition, $values, $limit);

The required params :

  • array|null $fields select attribute(s) of the table instatiated.
  • Sort datas with the string|null $condition if necessary.
# Query statement
$condition="name='john' and postname='doe'"
=> The $values param should have null value

# Prepared statement
$condition="name=? and postname=?"
=> The $values param should be an array
ex. $values = ['john', 'doe']

Note : The fields param can be initialize by '*' to return all datas.

  • array $values must get values of the attributes in the condition. Note : The initialisation of this variable require a prepared statement.
  • array|int $limit select datas. Else, you can use an array.
# Select only 5 datas
$limit = 5

# Select by the 5th to 10th data
$limit = [5, 10]

Update

The update operation refers to actions that modify existing data within a database or storage system. It allows you to change specific values or attributes of a record without deleting and recreating it entirely.

# Update users data
$users->update($id, $formData);

The required params :

  • int $id select the specific data to update.
  • array $formDatas contain new informations of a data.

Note : The array $formData should have the values of attributes of the table.

Delete

The Delete operation refers to the functionality that allows you to remove data from a database or storage system. It's the process of permanently erasing a specific record or set of records based on certain criteria.

# Remove a user data
$users->delete($id);

The required param :

  • With the int $id param, you can select the data.

📌 Conclusion

OpenCrud is a powerful tool for backend developers using native PHP. It simplifies connecting to MySQL databases and managing CRUD operations. However, this open-source project needs updates to improve performance and code maintainability. Without these improvements, its utility is limited to smaller projects.

About

open-crud is an open-source package created in native PHP that simplifies connecting to MySQL databases and makes it easier to manage databases using object-oriented programming.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages