2

我正在努力应对一些挑战,我想知道解决方案可能是什么,因为我在文档中找不到答案。

这是我当前的工作查询(部分):

$constraints[] = $query->like('kategorie', '%'.$kategorie.'%');

我想做的是:

$constraints[] = $query->like(CONCAT(',', kategorie, ','), '%,'.$kategorie.',%');

这显然根本不起作用。:-)

每个帮助真的很受欢迎。希望有人知道正确的语法。TYPO3 版本是最新的 6.1

非常感谢!

4

1 回答 1

1

首先,Extbase 查询生成在 6.0 中没有改变,所以对于 4.x 和 6.x 来说是一样的。

也许您误解了 Extbase 构建查询的方式。

$query->like('property', '%value%');

当 %value% 包含在“属性”中时,将返回一个对象。这样的属性必须在领域模型中定义。您只能查询在其域模型中具有“getProperty”方法的属性。

查看您的代码,我认为您正在寻找一种方法来查询逗号分隔值列表中存在的值?然后你会使用

$query->in('kategorien', $kategorie);

编辑:

您的具体问题似乎是您没有使用真正的关系将“类别”分配给您的实体。您正在使用逗号分隔的列表来保存对另一个模型的引用。不鼓励您这样做,但它在技术上是可行的,并且在 TYPO3 核心中使用: FrontendUser 模型具有以相同方式工作的属性“用户组”。

请查看 FrontendUser 模型:https ://git.typo3.org/Packages/TYPO3.CMS.git/blob/HEAD:/typo3/sysext/extbase/Classes/Domain/Model/FrontendUser.php

您的类别的注释必须正确,例如:

/**
* @var \TYPO3\CMS\Extbase\Persistence\ObjectStorage<\My\Extension\Domain\Model\Kategorien>
*/
protected $kategorien;

还要确保 getKategorien 是正确的。

如果您仍然有问题,请记住 TCA 定义必须正常工作才能使 Extbase 正常工作。

在我看来,最佳实践是使用 TYPO3 6.0 中引入的类别 API: http ://wiki.typo3.org/TYPO3_6.0#Category

于 2013-11-03T20:51:58.703 回答