首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从TCA typo3中的crdate中删除小时、分钟和秒

从TCA typo3中的crdate中删除小时、分钟和秒
EN

Stack Overflow用户
提问于 2018-09-03 17:44:21
回答 3查看 151关注 0票数 0

我在新闻tca中有这样的配置:

代码语言:javascript
运行
复制
'ctrl' => [
    'tstamp' => 'tstamp',
    'crdate' => 'crdate',

有了这个,新闻将像1535967103一样保存在数据库中,以小时、分钟和秒的形式保存。我想修剪这个信息,让它像1535932800一样

如何在TCA配置中获取此配置?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 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字段。

感谢大家的帮助。

票数 1
EN

Stack Overflow用户

发布于 2018-09-04 17:10:58

您始终可以按天进行排序,即使时间戳具有秒数。相同时间戳的其余排序条件通常是自动增量字段,因此按时间戳升序或降序排序的结果将是相同的。

除非您想按某一天分组,否则使用另一个时间戳不会有任何不同。

其他任何事情都可以在前端输出中完成,因此您可以在通过date或strftime格式化时间戳时跳过秒。

票数 1
EN

Stack Overflow用户

发布于 2018-09-03 18:04:06

tstamp和crdate不能四舍五入。它们总是每秒一次。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52147160

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档