我正在尝试使用pycassa添加主键。我可以使用 CQL3 来做到这一点,但我在网上找不到任何解释如何使用 Pycassa 来做到这一点的文档。我用谷歌搜索了太多,没有找到任何东西。
有谁知道如何使用 Pycassa 指定哪个将是我的列族的主键?
另外,我还有一个问题。是否可以有一个大的主键?例如 PRIMARY KEY(id、name、last_name、age)。
谢谢
最佳答案
是的,您可以拥有一个大的主键(“复合键”)。在您的示例中,id
将是分区键,name
、last_name
、age
是集群键。所有字段组合起来构成主键。
有关不同类型(和命名)键的详细解释,请查看 this SO answer .
This post给出了如何创建复合键的示例:
system_manager.create_column_family(..., key_validation_class="CompositeType(UTF8Type, Int32Type)")
对于你的数据,我猜:
system_manager.create_column_family(..., key_validation_class="CompositeType(Int32Type, UTF8Type, UTF8Type, Int32Type)")
我自己没用过pycassa,但是pycassa documentation有这个例子:
col_fam.insert('row_key', {'col_name': 'col_val'})
因此,我将大胆猜测您的情况(为了完整起见,添加几列):
col_fam.insert((id,name,last_name,age), {'firstname':first_name,'city':city})
关于cassandra - 如何使用 pycassa 指定主键?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33784431/