FIX Remove ambiguity for polymorphic queries (#11195)

This commit is contained in:
Guy Sartorelli 2024-04-12 09:40:34 +12:00 committed by GitHub
parent 97a8da8c7d
commit 6743de4356
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -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)
)); ));
} }