mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
FIX Remove ambiguity for polymorphic queries (#11195)
This commit is contained in:
parent
97a8da8c7d
commit
6743de4356
@ -57,7 +57,8 @@ class PolymorphicHasManyList extends HasManyList
|
|||||||
public function setForeignRelation(string $relationName): static
|
public function setForeignRelation(string $relationName): static
|
||||||
{
|
{
|
||||||
Deprecation::notice('5.2.0', 'Will be replaced with a parameter in the constructor');
|
Deprecation::notice('5.2.0', 'Will be replaced with a parameter in the constructor');
|
||||||
$this->dataQuery->where(["\"{$this->relationForeignKey}\"" => $relationName]);
|
$foreignRelationColumn = DataObject::getSchema()->sqlColumnForField($this->dataClass, $this->relationForeignKey);
|
||||||
|
$this->dataQuery->where([$foreignRelationColumn => $relationName]);
|
||||||
$this->dataQuery->setQueryParam('Foreign.Relation', $relationName);
|
$this->dataQuery->setQueryParam('Foreign.Relation', $relationName);
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
@ -102,8 +103,9 @@ class PolymorphicHasManyList extends HasManyList
|
|||||||
// For queries with multiple foreign IDs (such as that generated by
|
// For queries with multiple foreign IDs (such as that generated by
|
||||||
// DataList::relation) the filter must be generalised to filter by subclasses
|
// DataList::relation) the filter must be generalised to filter by subclasses
|
||||||
$classNames = Convert::raw2sql(ClassInfo::subclassesFor($foreignClass));
|
$classNames = Convert::raw2sql(ClassInfo::subclassesFor($foreignClass));
|
||||||
|
$foreignClassColumn = DataObject::getSchema()->sqlColumnForField($dataClass, $this->classForeignKey);
|
||||||
$this->dataQuery->where(sprintf(
|
$this->dataQuery->where(sprintf(
|
||||||
"\"{$this->classForeignKey}\" IN ('%s')",
|
"$foreignClassColumn IN ('%s')",
|
||||||
implode("', '", $classNames)
|
implode("', '", $classNames)
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user