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

Merge branch 'master' of git.unicaen.fr:/lib/unicaen/oracle

parents 0e0eb672 e55b7038
No related branches found
No related tags found
No related merge requests found
Pipeline #9154 passed
......@@ -19,4 +19,5 @@ cache:
update-satis:
stage: publish
script:
- update-satis
- curl https://gest.unicaen.fr/packagist/update
......@@ -3,13 +3,14 @@
namespace UnicaenOracle;
use Doctrine\DBAL\Driver\OCI8\Driver as OCI8;
use UnicaenOracle\ORM\Query\Functions\PasHistorise;
use UnicaenOracle\Controller\Factory\IndexControllerFactory;
use UnicaenOracle\Controller\IndexController;
use UnicaenOracle\DBAL\Event\Listeners\OracleSessionInit;
use UnicaenOracle\ORM\Query\Functions\Chr;
use UnicaenOracle\ORM\Query\Functions\CompriseEntre;
use UnicaenOracle\ORM\Query\Functions\Convert;
use UnicaenOracle\ORM\Query\Functions\PasHistorise;
use UnicaenOracle\ORM\Query\Functions\RegexpCount;
use UnicaenOracle\ORM\Query\Functions\Replace;
use UnicaenOracle\Service\DataService;
use UnicaenOracle\Service\SchemaService;
......@@ -27,6 +28,7 @@ return [
'CHR' => Chr::class,
'CONVERT' => Convert::class,
'REPLACE' => Replace::class,
'REGEXP_COUNT' => RegexpCount::class,
// fonctions du package PL/SQL "UNICAEN_ORACLE" (cf. "../data/package.sql")
'compriseEntre' => CompriseEntre::class,
......
<?php
namespace UnicaenOracle\ORM\Query\Functions;
use Doctrine\ORM\Query\Lexer;
use Doctrine\ORM\Query\AST\Functions\FunctionNode;
use Doctrine\ORM\Query\Parser;
use Doctrine\ORM\Query\SqlWalker;
/**
* Class RegexpCount
* @see https://stackoverflow.com/questions/32052563/doctrine-and-oracle-regexp-like
*/
class RegexpCount extends FunctionNode
{
public $field;
public $posixPattern;
public function parse(Parser $parser)
{
$parser->match(Lexer::T_IDENTIFIER);
$parser->match(Lexer::T_OPEN_PARENTHESIS);
$this->field = $parser->StringPrimary();
$parser->match(Lexer::T_COMMA);
$this->posixPattern = $parser->StringPrimary();
$parser->match(Lexer::T_CLOSE_PARENTHESIS);
}
public function getSql(SqlWalker $sqlWalker)
{
return sprintf('REGEXP_COUNT(%s, %s)',
$this->field->dispatch($sqlWalker),
$this->posixPattern->dispatch($sqlWalker));
}
}
\ No newline at end of file
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment