首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用cqlengine在Cassandra中定义冻结的列?

如何使用cqlengine在Cassandra中定义冻结的列?
EN

Stack Overflow用户
提问于 2019-01-07 07:24:30
回答 1查看 166关注 0票数 0

我正在尝试在Cassandra中创建一个冻结列表,这样我就可以使用该列作为主键,如果我手动运行查询,就可以做到这一点。

代码语言:javascript
复制
some_field frozen <list<int>>

但是我很难弄清楚如何在Python中使用cqlengine,

代码语言:javascript
复制
some_field = columns.List(columns.Integer(), primary_key=True)

我如何使用cqlengine来完成同样的事情?

编辑:最终代码片段如下所示,

代码语言:javascript
复制
from cassandra.cqlengine import columns
from cassandra.cqlengine.models import Model

class MyModel(Model):
    __table_name__ = 'my_table'
    __options__ = {'compaction': {'class': 'DateTieredCompactionStrategy',
                              'base_time_seconds': 3600,
                              'max_sstable_age_days': 1}}

    keys = columns.Set(columns.Integer(), primary_key=True)
    columns.BaseCollectionColumn._freeze_db_type(keys)
    time_stamp = columns.DateTime(primary_key=True, clustering_order="DESC")
    ...
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-01-14 19:54:30

作为I see in the source code,您需要在创建集合类型的实例后调用函数_freeze_db_type -这会将类型更改为frozen<...>

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

https://stackoverflow.com/questions/54066830

复制
相关文章

相似问题

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