nosql – Cassandra CompositeType
发布时间:2020-12-13 13:55:04 所属栏目:百科 来源:网络整理
导读:我在Hector和Cassandra教程中看到有DynamicCompositeType. 任何人都可以详细说明它们之间的区别 create column family Composite with comparator ='DynamicCompositeType (t=TimeUUIDType,s=UTF8Type)' and default_validation_class=UTF8Type and key_vali
我在Hector和Cassandra教程中看到有DynamicCompositeType.
任何人都可以详细说明它们之间的区别 create column family Composite with comparator ='DynamicCompositeType (t=>TimeUUIDType,s=>UTF8Type)' and default_validation_class=UTF8Type and key_validation_class=UTF8Type; 和 create column family Composite with comparator = 'CompositeType(TimeUUIDType,UTF8Type)' and key_validation_class = 'UTF8Type' and default_validation_class = 'UTF8Type' 我没有在Cassandra文档中找到它
了解Cassandra如何存储数据以及实际的复合材料可能有所帮助:
>无论您使用哪个验证器/比较器,所有数据都存储为字节.当您指定验证器时,您只是要求Cassandra确保根据需要对这些字节进行编码.相比之下,比较器只是根据您给出的编码特定的自然顺序对列进行排序.>然后,复合材料只是具有特定编码的字节数组.这种编码非常简单:对于每个组件,它存储两个字节的长度,然后是字节编码的组件,后跟一个终止位,用于确定它是包含还是独占.由于任何东西都可以存储在字节数组中,因此您可以使用不同的组件类型 – 但您必须知道它们是什么并自行解码/编码.>为了实现动态合成,Hector将其他类型数据写入字节数组,以便它在读取字节时知道如何解码字节.由于没有类型信息,静态合成无法执行此操作. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |