繁体   English   中英

TYPO3逻辑或数据库查询中的优先级

[英]prioritize in TYPO3 logicalOr database query

我想在TYPO3中创建一个数据库查询。 我想区分不同的sys_language_uids。

        $lanuageUid = $demand->getLanguageUid();
        if (isset($lanuageUid)) {
            $constraints['sys_language_uid'] = $query->logicalOr(
                [
                    $query->equals('sys_language_uid', 0),
                    $query->equals('sys_language_uid', $demand->getLanguageUid()),

                ]
            );
        }

我想要返回一定数量的记录,这些记录是使用setLimit()设置的; 假设最近的languageUid用于西班牙,0用于英语。 我要回3条记录,但西班牙只有2条记录,所以我要用英语写最后一条记录。 我最近的查询只是给我排序的记录。 但是我可以说我首先想要所有西班牙语记录,然后再说,如果它们小于3,我想要英语中的剩余记录?

我会用$ defaultOrderings做到这一点。

$this->setDefaultOrderings([
    'sys_language_uid' => \TYPO3\CMS\Extbase\Persistence\QueryInterface::ORDER_DESCENDING
]);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM