我在新闻tca中有这样的配置:
'ctrl' => [
'tstamp' => 'tstamp',
'crdate' => 'crdate',有了这个,新闻将像1535967103一样保存在数据库中,以小时、分钟和秒的形式保存。我想修剪这个信息,让它像1535932800一样
如何在TCA配置中获取此配置?
发布于 2018-09-06 15:32:41
好的,我用datetime创建了一个新字段,它的值和crdate相同。
然后我创建了processDatamap_preProcessFieldArray(&$fieldArray, $table),我这样做:
$dateTime = (new \DateTime())->setTimestamp($fieldArray['datetime']); $dateTime->setTime(00, 00, 00); $fieldArray['datetime'] = $dateTime->getTimestamp();
在ext_localconf中,我添加了:
$GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['t3lib/class.t3lib_tcemain.php']['processDatamapClass']['si_news'] = \Sozialinfo\SiNews\Hooks\TCEmainHook::class; $GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['t3lib/class.t3lib_tcemain.php']['processCmdmapClass']['si_news'] = \Sozialinfo\SiNews\Hooks\TCEmainHook::class;
现在我有了没有小时、分钟和秒的crdate (在新的字段中,crdate保持不变),并且我可以使用这个字段进行排序。
我找到的从crdate中删除秒数的唯一解决方案是使用processDatamap_afterDatabaseOperations并使用带有$GLOBALS['TYPO3_DB']的自定义查询。它有点脏。
我使用新字段而不是重写crdate,因为有人说: crdate是一个内部TYPO3字段。所以我没有改变内部的TYPO3字段。
感谢大家的帮助。
发布于 2018-09-04 17:10:58
您始终可以按天进行排序,即使时间戳具有秒数。相同时间戳的其余排序条件通常是自动增量字段,因此按时间戳升序或降序排序的结果将是相同的。
除非您想按某一天分组,否则使用另一个时间戳不会有任何不同。
其他任何事情都可以在前端输出中完成,因此您可以在通过date或strftime格式化时间戳时跳过秒。
发布于 2018-09-03 18:04:06
tstamp和crdate不能四舍五入。它们总是每秒一次。
https://stackoverflow.com/questions/52147160
复制相似问题