1. Go to this page and download the library: Download somnambulist/cte-builder library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
somnambulist / cte-builder example snippets
use Somnambulist\Components\CTEBuilder\ExpressionBuilder;
$eb = new ExpressionBuilder($connection);
$expr = $eb->createExpression('first_clause');
$result = $eb->select('field', 'another field')->from('table_or_cte')->execute();
use Somnambulist\Components\CTEBuilder\ExpressionBuilder;
$eb = new ExpressionBuilder($connection);
$expr1 = $eb->createExpression('first_clause');
$expr1->from('second_clause');
$expr2 = $eb->createExpression('second_clause');
$expr1->dependsOn('second_clause');
use Somnambulist\Components\CTEBuilder\ExpressionBuilder;
$eb = new ExpressionBuilder($connection);
$expr1 = $eb->createExpression('first_clause', 'second_clause');
$expr1->from('second_clause');
use Somnambulist\Components\CTEBuilder\ExpressionBuilder;
$eb = new ExpressionBuilder($connection);
$eb->createExpression('first_clause');
$eb->createExpression('second_clause');
$eb->createExpression('third_clause');
$eb->third_clause->select();
use Somnambulist\Components\CTEBuilder\ExpressionBuilder;
$eb = new ExpressionBuilder($connection);
$expr = $eb->createExpression('unioned_data');
$expr->select('field1', 'field2')->from('some_table');
$otherData = $eb->createDetachedExpression();
$otherData->select('id AS field1', 'name AS field2')->from('some_other_table');
$otherData2 = $eb->createDetachedExpression();
$otherData2->select('id AS field1', 'name AS field2')->from('some_other_table');
$expr->union($otherData, $otherData2);
//$expr->unionAll($otherData, $otherData2);
$cte = new ExpressionBuilder($conn);
// this is just as example, this is a poor use of CTEs
$users = $cte->createExpression('only_users');
$users->select('*')->from('users')->where('type = :type')->setParameter('type', 'user');
$cte->select('*')->from('only_users');
$paginator = new PagerfantaAdapter($cte, function (ExpressionBuilder $qb) {
$qb->select('COUNT(*) AS total_results');
});
$pf = new Pagerfanta($paginator);
$pf->setMaxPerPage(1)->setCurrentPage(3);
foreach ($pf as $result) {
dump($result);
}
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.