datatables.net / editor-php
PHP server-side libraries for DataTables
Requires
- php: >=5.4.0 <9
Requires (Dev)
- friendsofphp/php-cs-fixer: ~3.41.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan: ~1.11
- phpstan/phpstan-deprecation-rules: ^1.0
This package is auto-updated.
Last update: 2026-05-04 13:24:23 UTC
README
This is a PHP library to provide easy server-side support for DataTables - the Javascript table library.
These libraries provide support for:
- Server-side processing - work with millions of rows
- Editor - CRUD UI for DataTables
- ColumnControl - Column search controls for DataTables
- SearchBuilder - Complex search logic UI
The library is framework-agnostic and can be used in any web framework, including Laravel, Symfony and CodeIgniter. It is dependency free, other than PHP core with PDO, and uses a database abstraction layer to operate with MySQL, Postgres, SQLite and SQLServer, using the same API.
Installation
Available on Packagist, this package can be installed with:
composer require datatables.net/editor-php
Then add:
require 'vendor/autoload.php'
to your files that use the DataTables classes. The required classes will be automatically included as you use them.
If you prefer not to use composer and include the PHP files directly, download them and require the DataTables.php file, which will load the auto loader for the classes:
require( $_SERVER['DOCUMENT_ROOT'] . 'lib/DataTables.php' );
Database connection
You must create a database connection using the Database class. This can be done automatically by defining the array $sql_details in config.php, or creating a new Database() class instance directly:
$db = new Database( [ 'type' => '', // Database type: "Mysql", "Postgres", "Sqlserver", "Sqlite" 'user' => '', // Database user name 'pass' => '', // Database password 'host' => '', // Database host 'port' => '', // Database connection port (can be left empty for default) 'db' => '' // Database name ]);
There are two primary entry point classes in the library:
DataTable- for read only tablesEditor- for read / write tables, with Editor
There are also a number of supporting classes such as Options, Mjoin and more.
Quick Start
Once a database connection is configured, you can use the library to read and write data on a database - e.g. the following is a simple PHP file that acts as a CRUD end point for for a DataTables / Editor client-side:
<?php // DataTables PHP library include( "../lib/DataTables.php" ); // Alias the namespaces so the classes are easy to use use DataTables\Editor, DataTables\Editor\Field, DataTables\Editor\Format, DataTables\Editor\Mjoin, DataTables\Editor\Options, DataTables\Editor\Upload, DataTables\Editor\Validate, DataTables\Editor\ValidateOptions; // Build our Editor instance and process the data coming from $_POST new Editor( $db, 'datatables_demo' ) ->fields( new Field( 'first_name' ) ->validator( Validate::notEmpty( new ValidateOptions() ->message( 'A first name is required' ) ) ), new Field( 'last_name' ) ->validator( Validate::notEmpty( new ValidateOptions() ->message( 'A last name is required' ) ) ), new Field( 'position' ), new Field( 'email' ) ->validator( Validate::email( new ValidateOptions() ->message( 'Please enter an e-mail address' ) ) ), new Field( 'office' ), new Field( 'extn' ), new Field( 'age' ) ->validator( Validate::numeric() ) ->setFormatter( Format::ifEmpty(null) ), new Field( 'salary' ) ->validator( Validate::numeric() ) ->setFormatter( Format::ifEmpty(null) ), new Field( 'start_date' ) ->validator( Validate::dateFormat( 'Y-m-d' ) ) ->getFormatter( Format::dateSqlToFormat( 'Y-m-d' ) ) ->setFormatter( Format::dateFormatToSql('Y-m-d' ) ) ) ->process( $_POST ) ->json();
Note that the above uses PHP 8.4 syntax to chain a constructor without parentheses. If you are using an older version of PHP you can use either:
(new Editor($db, 'name'))->fields(...)Editor:inst($db, 'name')->fields(...)
Similarly, if your table is readonly, the DataTable and Column classes can be used (this will support DataTables' client-side or server-side processing modes):
<?php include( "../lib/DataTables.php" ); use DataTables\DataTable, DataTables\DataTable\Column; new DataTable( $db, 'datatables_demo' ) ->columns( new Column( 'first_name' ), new Column( 'last_name' ), new Column( 'position' ), new Column( 'email' ), new Column( 'office' ) ) ->process( $_POST ) ->json();
Documentation
For full documentation, please refer to the DataTables site.
License
MIT — see LICENSE for full text.