首页 文章

typo3 extbase - 双向关系

提问于
浏览
0

我有两个表:fe_users(对于我的前端用户)和tx_somethingarticles_domain_model_article . 用户应该能够“喜欢”一篇文章,所以对于每个用户,如果他已经喜欢某篇文章,我需要这些信息,而且我还需要知道文章已经有多少喜欢的信息 . 所以我相信我需要的是双向mm关系,但我似乎无法让它工作 . 我有我的用户实体,看起来像这样:

/**
 * articleLike
 *
 * @var \TYPO3\CMS\Extbase\Persistence\ObjectStorage<\Package\SomethingArticles\Domain\Model\Article>
 */
protected $articleLike = NULL;

public function addArticlesLike(\Package\SomethingArticles\Domain\Model\Article $articlesLike) {
    $this->articlesLike->attach($articlesLike);
}

public function removeArticlesLike(\Package\SomethingArticles\Domain\Model\Article $remove) {
    $this->articlesLike->detach($remove);
}

public function getArticlesLike() {
    return $this->articlesLike;
}

public function setArticlesLike(\TYPO3\CMS\Extbase\Persistence\ObjectStorage $articlesLike) {
    $this->articlesLike = $articlesLike;
}

我的文章实体有这样的:protected $ articlesLike = NULL;

public function getArticlesLike() {
    return $this->articlesLike;
}

与getArticlesLike我希望得到所有喜欢的文章 . 我的用户tca.php有article_like列,如下所示:

'articles_like' => array(
        'exclude' => 1,
        'label' => 'LLL:EXT:something_articles/Resources/Private/Language/locallang_db.xlf:tx_somethingarticles_domain_model_user.articles_like',
        'config' => array(
            'type' => 'group',
            'internal_type' => 'db',
            'foreign_table' => 'tx_somethingarticles_domain_model_article',
            'allowed' => '*',
            'MM' => 'tx_somethingarticles_user_articleslike_article_mm',
            'MM_opposite_field' => 'articles_like',
            'size' => 10,
            'autoSizeMax' => 30,
            'maxitems' => 9999,
            'multiple' => 0,
        ),
    ),

和我的文章的tca.php:

'articles_like' => array(
            'exclude' => 1,
            'label' => 'LLL:EXT:something_articles/Resources/Private/Language/locallang_db.xlf:tx_somethingarticles_domain_model_article.articles_like',
            'config' => array(
                'type' => 'group',
                'internal_type' => 'db',
                'allowed' => '*',
                'foreign_table' => 'fe_users',
                'MM' => 'tx_somethingarticles_user_articleslike_article_mm',
                'maxitems'   => 9999,
            ),
        ),

当我获取用户并尝试类似$ user-> getArticlesLike()的东西时,它的效果非常好,我还可以附加新的喜欢,就像魅力一样 . 但是当我尝试$ article-> getArticlesLike()时...它总是空的 . 我错过了什么?

我真的很绝望,过去10个小时我一直试图解决这个问题,我似乎无法找到解决方案 . 任何帮助都非常感谢 .

2 回答

  • 1

    对文章TCA使用以下列配置:

    'foreign_table' => 'tx_somethingarticles_user_articleslike_article_mm'
    

    并删除MM :)

  • 1

    我们遇到了同样的问题,并且记录了on this websitein the documentation两件事情是必不可少的 .

    • 在TCA中确保您设置的两个相关表格:
    'multiple' => 1
    
    • 你的MM表应该有一个字段“sorting_foreign”,所以你的ext_tables.sql应该有这样的定义:
    sorting_foreign int(11) DEFAULT '0' NOT NULL
    

相关问题