Skip to content

Latest commit

 

History

History
 
 

Dialect

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Phalcon\Db\Dialect

MysqlExtended

Generates database specific SQL for the MySQL RDBMS.

This is an extended MySQL dialect that introduces workarounds for some common MySQL-only functions like search based on FULLTEXT indexes and operations with date intervals. Since PHQL does not support these syntax you can use these functions:

use Phalcon\Db\Adapter\Pdo\Mysql;
use Phalcon\Db\Adapter\Pdo\MysqlExtended;

$di->set('db', function() {
    /** @var \Phalcon\DiInterface $this */
    return new Mysql([
        'host'         => $this->getShared('config')->database->host,
        'username'     => $this->getShared('config')->database->username,
        'password'     => $this->getShared('config')->database->password,
        'dbname'       => $this->getShared('config')->database->name,
        'dialectClass' => MysqlExtended::class
    ]);
});

Usage:

// SELECT `customers`.`created_at` - INTERVAL 7 DAY FROM `customers`
$data = $this->modelsManager->executeQuery(
    'SELECT created_at - DATE_INTERVAL(7, "DAY") FROM App\Models\Customers'
);

// SELECT `customers`.`id`, `customers`.`name` FROM `customers`
// WHERE MATCH(`customers`.`name`, `customers`.`description`) AGAINST ("+CEO")
$data = $this->modelsManager->executeQuery(
    'SELECT id, name FROM App\Models\Customers WHERE FULLTEXT_MATCH(name, description, "+CEO")'
);

// SELECT `customers`.`id`, `customers`.`name` FROM `customers`
// WHERE MATCH(`customers`.`name`, `customers`.`description`) AGAINST ("+CEO" IN BOOLEAN MODE)
$data = $this->modelsManager->executeQuery(
    'SELECT id, name FROM App\Models\Customers WHERE FULLTEXT_MATCH_BMODE(name, description, "+CEO")'
);

Oracle

Generates database specific SQL for the Oracle RDBMS.