ocolin / easydb
Simple, lightweight PDO database handler with environment variable support
Requires
- php: >=8.2
- ext-pdo: *
- ocolin/easyenv: ^3.0
- ocolin/global-type: ^2.0
Requires (Dev)
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^13.0
README
About
EasyDB is a simple lightweight PDO wrapper for creating a quick database handler using environment variables.
EasyDB uses a prefix system so that you can add a DB handler with a single string parameter. That prefix tells EasyDB which environment parameters to load. So your code will look very short, easy, and readable.
Requirements
This plugin was designed for PHP 8.2 or above.
Installation
composer require Ocolin\Easy-db
Usage
Quick connection from environment variables
Explanation
The key feature to this tool is the prefix. You provide a prefix string which will be used to find the needed environment variables that start with that prefix name. This saves you from having to specify the parameters needed and also allow you to have multiple handlers distinguished by prefix name.
Here are the environment variables that get loaded. In this example, the prefix is "PREFIX":
- PREFIX_DB_HOST
- PREFIX_DB_NAME
- PREFIX_DB_USER
- PREFIX_DB_PASS
- PREFIX_DB_PORT
Code example:
// Setting up variables manually for visual purposes $_ENV['PREFIX_DB_HOST'] = 'localhost'; $_ENV['PREFIX_DB_NAME'] = 'mydb'; $_ENV['PREFIX_DB_USER'] = 'admin'; $_ENV['PREFIX_DB_PASS'] = 'password1234'; $_ENV['PREFIX_DB_PORT'] = 3306 // This is the default so does not need to be set. $prefix_db = Ocolin\EasyDB\DB::fromEnv( prefix: 'PREFIX' );
If you don't have a means of loading environment variables or want to use this as a stand alone, you can specify a file with your environment variables:
/* * Contents of .env file: * MYDATA_DB_HOST=localhost * MYDATA_DB_NAME=mydb * MYDATA_DB_USER=admin * MYDATA_DB_PASS=password1234 */ $prefix_db = Ocolin\EasyDB\DB::fromEnv( prefix: 'MYDATA', files: __DIR__ . '/../.env' );
Direct connection
EasyDB also has a direct connection function for use without environment variables.
$pdo_handler = Ocolin\EasyDB\DB::connect( host: 'localhost', name: 'mydb', user: 'admin', pass: 'password1234', port: 3306 // This is default and does not need to be set. );
NOTE: the host parameter defaults to 'localhost', so it can be skipped when working on localhost.
Options
By default EasyDB sets the following PDO options:
- PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
- PDO::ATTR_STRINGIFY_FETCHES => FALSE
- PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC
The options argument takes an array of options. These can override the defaults or ad additional options. Please see the PDO manual for which options and their settings are valid.
Query
An additional helper library is added to assist with building some of the more basic SQL queries.
createColumns
This function takes an array of database column names and create a coma separated string that can be used in an SQL query to specify columns to return in a SELECT query.
$output = Ocolin\EasyDB\Query::createColumns( params: [ 'A' => '1', 'B' => '2', 'C' => '3'] ); // output: `A`, `B`, `C`
createColumnValues
This function takes an associative array and builds a coma separated variable names for an INSERT type os query.
$output = Ocolin\EasyDB\Query::createColumnValues( params: [ 'A' => '1', 'B' => '2', 'C' => '3'] ); // output: ":A, :B, :C"
replaceInto
Using the previous two functions we can create an SQL REPLACE INTO query providing just an array.
$output = Ocolin\EasyDB\Query::replaceInto( table: 'mytable', params: [ 'A' => '1', 'B' => '2', 'C' => '3' ] ); /* REPLACE INTO mytable ( `A`, `B`, `C` ) VALUES ( :A, :B, :C ) */
bindParameters
This function allows you to bind data to your PDO query parameters. It requires a pointer to your PDO statement handler, and an array of your data.
Ocolin\EasyDB\Query::bindParameters( query: $pdo_statement, params: [ 'A' => '1', 'B' => '2', 'C' => '3' ] );
Used in conjunction with a function like replaceInto(), it will bind those array values to the matching parameter names in your PDO query statement.
bindValues
This is similar to bind parameters but does so with values.
Ocolin\EasyDB\Query::bindValues( query: $pdo_statement, params: [ 'A' => '1', 'B' => '2', 'C' => '3' ] );
filterColumns
This function is helpful when you have more data than you want to update. Perhaps you have an array with data that you don't want to overwrite such as the column index of the table. This basic function will strip out the columns that are not allowed.
$newparams = Ocolin\EasyDB\Query::filterColumns( params: [ 'A' => '1', 'B' => '2', 'C' => '3' ], allowed: [ 'A', 'B', 'D' ] ) // $newparams = [ 'A' => '1', 'B' => '2' ] $output = Ocolin\EasyDB\Query::replaceInto( table: 'mytable', params: $newparams );
Validate
Another utility provided is a series of static functions for validating data being sent to the database. There is a function for each COLUMN data type and each function is named in format of "is" + the column type name.
The function will respond with TRUE if the data is valid, or an error string explaining why it is not valid. Here is a list of helper functions:
| Function | Arguments | Argument Types |
|---|---|---|
| isINT | input,unsigned | mixed,bool |
| isTINYINT | input,unsigned | mixed,bool |
| isSMALLINT | input,unsigned | mixed,bool |
| isMEDIUMINT | input,unsigned | mixed,bool |
| isBIGINT | input,unsigned | mixed,bool |
| isBOOLEAN | input | mixed |
| isDECIMAL | input,precision,scale | mixed,int,int |
| isFLOAT | input,precision,scale | mixed,int,int |
| isCHAR | input,length | mixed,int |
| isVARCHAR | input,length | mixed,int |
| isTINYTEXT | input | mixed |
| isTEXT | input | mixed |
| isMEDIUMTEXT | input | mixed |
| isLONGTEXT | input | mixed |
| isENUM | input,allowed | mixed,array |
| isDATE | input | mixed |
| isTIME | input | mixed |
| isTIMESTAMP | input | mixed |
| isDATETIME | input | mixed |
| isYEAR | input | mixed |
Example:
$output = Ocolin\EasyDB\Validate::isCHAR( input: ['A'] ); // "CHAR: Input must be a string, got array." $output = Ocolin\EasyDB\Validate::isCHAR( input: 'A' ); // TRUE