Skip to content
Snippets Groups Projects
Commit 2c6bc430 authored by Bertrand Gauthier's avatar Bertrand Gauthier
Browse files

Suppression du support (impossible) de la fonction REGEXP_LIKE et remplacement par REGEXP_COUNT()

parent f53b6809
No related branches found
No related tags found
No related merge requests found
Pipeline #9009 failed
...@@ -3,14 +3,14 @@ ...@@ -3,14 +3,14 @@
namespace UnicaenOracle; namespace UnicaenOracle;
use Doctrine\DBAL\Driver\OCI8\Driver as OCI8; use Doctrine\DBAL\Driver\OCI8\Driver as OCI8;
use UnicaenOracle\ORM\Query\Functions\PasHistorise;
use UnicaenOracle\Controller\Factory\IndexControllerFactory; use UnicaenOracle\Controller\Factory\IndexControllerFactory;
use UnicaenOracle\Controller\IndexController; use UnicaenOracle\Controller\IndexController;
use UnicaenOracle\DBAL\Event\Listeners\OracleSessionInit; use UnicaenOracle\DBAL\Event\Listeners\OracleSessionInit;
use UnicaenOracle\ORM\Query\Functions\Chr; use UnicaenOracle\ORM\Query\Functions\Chr;
use UnicaenOracle\ORM\Query\Functions\CompriseEntre; use UnicaenOracle\ORM\Query\Functions\CompriseEntre;
use UnicaenOracle\ORM\Query\Functions\Convert; use UnicaenOracle\ORM\Query\Functions\Convert;
use UnicaenOracle\ORM\Query\Functions\RegexpLike; use UnicaenOracle\ORM\Query\Functions\PasHistorise;
use UnicaenOracle\ORM\Query\Functions\RegexpCount;
use UnicaenOracle\ORM\Query\Functions\Replace; use UnicaenOracle\ORM\Query\Functions\Replace;
use UnicaenOracle\Service\DataService; use UnicaenOracle\Service\DataService;
use UnicaenOracle\Service\SchemaService; use UnicaenOracle\Service\SchemaService;
...@@ -28,7 +28,7 @@ return [ ...@@ -28,7 +28,7 @@ return [
'CHR' => Chr::class, 'CHR' => Chr::class,
'CONVERT' => Convert::class, 'CONVERT' => Convert::class,
'REPLACE' => Replace::class, 'REPLACE' => Replace::class,
'REGEXP_LIKE' => RegexpLike::class, 'REGEXP_COUNT' => RegexpCount::class,
// fonctions du package PL/SQL "UNICAEN_ORACLE" (cf. "../data/package.sql") // fonctions du package PL/SQL "UNICAEN_ORACLE" (cf. "../data/package.sql")
'compriseEntre' => CompriseEntre::class, 'compriseEntre' => CompriseEntre::class,
......
...@@ -7,7 +7,11 @@ use Doctrine\ORM\Query\AST\Functions\FunctionNode; ...@@ -7,7 +7,11 @@ use Doctrine\ORM\Query\AST\Functions\FunctionNode;
use Doctrine\ORM\Query\Parser; use Doctrine\ORM\Query\Parser;
use Doctrine\ORM\Query\SqlWalker; use Doctrine\ORM\Query\SqlWalker;
class RegexpLike extends FunctionNode /**
* Class RegexpCount
* @see https://stackoverflow.com/questions/32052563/doctrine-and-oracle-regexp-like
*/
class RegexpCount extends FunctionNode
{ {
public $field; public $field;
public $posixPattern; public $posixPattern;
...@@ -24,7 +28,7 @@ class RegexpLike extends FunctionNode ...@@ -24,7 +28,7 @@ class RegexpLike extends FunctionNode
public function getSql(SqlWalker $sqlWalker) public function getSql(SqlWalker $sqlWalker)
{ {
return sprintf('REGEXP_LIKE(%s, %s)', return sprintf('REGEXP_COUNT(%s, %s)',
$this->field->dispatch($sqlWalker), $this->field->dispatch($sqlWalker),
$this->posixPattern->dispatch($sqlWalker)); $this->posixPattern->dispatch($sqlWalker));
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment