specific rewrittend url retrievement
This commit is contained in:
@@ -59,8 +59,9 @@ class RewritingRetriever
|
|||||||
{
|
{
|
||||||
$urlQuery = RewritingUrlQuery::create()
|
$urlQuery = RewritingUrlQuery::create()
|
||||||
->joinRewritingArgument('ra', Criteria::LEFT_JOIN)
|
->joinRewritingArgument('ra', Criteria::LEFT_JOIN)
|
||||||
->withColumn('`ra`.PARAMETER', 'ra_parameter')
|
//->withColumn('`ra`.PARAMETER', 'ra_parameter')
|
||||||
->withColumn('`ra`.VALUE', 'ra_value')
|
//->withColumn('`ra`.VALUE', 'ra_value')
|
||||||
|
->withColumn('`ra`.REWRITING_URL_ID', 'ra_REWRITING_URL_ID')
|
||||||
->filterByView($view)
|
->filterByView($view)
|
||||||
->filterByViewLocale($viewLocale)
|
->filterByViewLocale($viewLocale)
|
||||||
->filterByViewId($viewId)
|
->filterByViewId($viewId)
|
||||||
@@ -70,23 +71,23 @@ class RewritingRetriever
|
|||||||
$otherParametersCount = count($viewOtherParameters);
|
$otherParametersCount = count($viewOtherParameters);
|
||||||
if($otherParametersCount > 0) {
|
if($otherParametersCount > 0) {
|
||||||
$parameterConditions = array();
|
$parameterConditions = array();
|
||||||
|
|
||||||
foreach($viewOtherParameters as $parameter => $value) {
|
foreach($viewOtherParameters as $parameter => $value) {
|
||||||
$conditionName = 'other_parameter_condition_' . count($parameterConditions);
|
$conditionName = 'other_parameter_condition_' . count($parameterConditions);
|
||||||
$urlQuery->condition('parameter_condition', '`ra_parameter`= ?', $parameter, \PDO::PARAM_STR)
|
$urlQuery->condition('parameter_condition', '`ra`.PARAMETER= ?', $parameter, \PDO::PARAM_STR)
|
||||||
->condition('value_condition', '`ra_value` = ?', $value, \PDO::PARAM_STR)
|
->condition('value_condition', '`ra`.VALUE = ?', $value, \PDO::PARAM_STR)
|
||||||
->combine(array('parameter_condition', 'value_condition'), Criteria::LOGICAL_AND, $conditionName);
|
->combine(array('parameter_condition', 'value_condition'), Criteria::LOGICAL_AND, $conditionName);
|
||||||
$parameterConditions[] = $conditionName;
|
$parameterConditions[] = $conditionName;
|
||||||
}
|
}
|
||||||
|
|
||||||
$urlQuery->combine($parameterConditions, Criteria::LOGICAL_OR, 'parameter_full_condition');
|
$urlQuery->where($parameterConditions, Criteria::LOGICAL_OR);
|
||||||
|
|
||||||
$urlQuery->groupBy(RewritingUrlTableMap::ID);
|
$urlQuery->groupBy(RewritingUrlTableMap::ID);
|
||||||
|
|
||||||
$urlQuery->condition('count_condition', 'COUNT(' . RewritingUrlTableMap::ID . ') = ?', $otherParametersCount, \PDO::PARAM_INT)
|
$urlQuery->condition('count_condition_1', 'COUNT(' . RewritingUrlTableMap::ID . ') = ?', $otherParametersCount, \PDO::PARAM_INT) // ensure we got all the asked parameters (provided by the query)
|
||||||
->combine(array('count_condition', 'parameter_full_condition'), Criteria::LOGICAL_AND, 'full_having_condition');
|
->condition('count_condition_2', 'COUNT(' . RewritingUrlTableMap::ID . ') = (SELECT COUNT(*) FROM rewriting_argument WHERE rewriting_argument.REWRITING_URL_ID = ra_REWRITING_URL_ID)'); // ensure we don't miss any parameters (needed to match the rewritten url)
|
||||||
|
|
||||||
|
$urlQuery->having(array('count_condition_1', 'count_condition_2'), Criteria::LOGICAL_AND);
|
||||||
$urlQuery->having(array('full_having_condition'));
|
|
||||||
} else {
|
} else {
|
||||||
$urlQuery->where('ISNULL(`ra`.REWRITING_URL_ID)');
|
$urlQuery->where('ISNULL(`ra`.REWRITING_URL_ID)');
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user