Extbase 查询比较相同 table 中的两个字段
Extbase query to compare two fields in same table
是否可以比较查询中的两个数据库字段api?例如,我想比较字段 tstamp 和 crdate,如:
SELECT * FROM tt_content WHERE tstamp > crdate;
在查询中 api 我找不到解决方案。获取所有记录并比较循环中的字段不是一种执行方式,因为这可能超过 200 万条记录(在我的真实情况下)。
感谢您的帮助。
我能想到的(并且查询构建器支持的)唯一方法是直接提供语句。它看起来像这样:
$query = $contentElementRepository->createQuery();
$query->statement('SELECT * FROM tt_content WHERE tstamp > crdate');
$matchingContentElements = $query->execute();
这可能会破坏数据库抽象层,因此请谨慎使用。 statement()
有第二个参数,您可以在其中放置参数,以防您在查询中需要一些用户输入。
也许还有另一种我不知道的方法,我自己也会很感兴趣。
是否可以比较查询中的两个数据库字段api?例如,我想比较字段 tstamp 和 crdate,如:
SELECT * FROM tt_content WHERE tstamp > crdate;
在查询中 api 我找不到解决方案。获取所有记录并比较循环中的字段不是一种执行方式,因为这可能超过 200 万条记录(在我的真实情况下)。
感谢您的帮助。
我能想到的(并且查询构建器支持的)唯一方法是直接提供语句。它看起来像这样:
$query = $contentElementRepository->createQuery();
$query->statement('SELECT * FROM tt_content WHERE tstamp > crdate');
$matchingContentElements = $query->execute();
这可能会破坏数据库抽象层,因此请谨慎使用。 statement()
有第二个参数,您可以在其中放置参数,以防您在查询中需要一些用户输入。
也许还有另一种我不知道的方法,我自己也会很感兴趣。