首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >由于布尔列,Cassandra不会在TTL过期后删除行。

由于布尔列,Cassandra不会在TTL过期后删除行。
EN

Stack Overflow用户
提问于 2019-08-14 08:47:05
回答 1查看 821关注 0票数 0

有了一个将TTL设置为7天的表,我希望Cassandra会在7天后删除这些行。

我的表包含布尔列,它们只在表上创建新行时将列设置为True。这些列永远不会更新为新值,因此这些列不会用新的TTL值来更改TTL值(因为Cassandra是面向列的数据库)。

但是,我注意到,7天后,所有列都被设置为空值(预期将被删除),除了那些保持为True的布尔列之外,因此,这些行永远不会被删除。检查所有列的TTL值,它们有空值,这意味着TTL已过期在所有列上,包括布尔列。

当手动将布尔列设置为NULL时(7天之后),行将按预期立即移除。

我不明白为什么Cassandra在TTL过期后不将布尔列设置为NULL,因此行将自动删除。Cassandra是否以不同的方式与布尔列和TTL值一起工作?

与以下方面合作:

  • Python 3.6和
  • 卡桑德拉3.11
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-08-28 09:22:06

解决方案:运行nodetool flush后,问题得到修复,并在TTL过期时删除行。

这真的很奇怪,但它正在工作,我可以看到行立即被删除。我找不到不删除表中过期行的原因,即使这些行已在马厩上标记为过期(expires= true)。

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

https://stackoverflow.com/questions/57491220

复制
相关文章

相似问题

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