我在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如何存储数据以及实际的复合材料可能有所帮助:
原文链接:https://www.f2er.com/nosql/238931.html>无论您使用哪个验证器/比较器,所有数据都存储为字节.当您指定验证器时,您只是要求Cassandra确保根据需要对这些字节进行编码.相比之下,比较器只是根据您给出的编码特定的自然顺序对列进行排序.>然后,复合材料只是具有特定编码的字节数组.这种编码非常简单:对于每个组件,它存储两个字节的长度,然后是字节编码的组件,后跟一个终止位,用于确定它是包含还是独占.由于任何东西都可以存储在字节数组中,因此您可以使用不同的组件类型 – 但您必须知道它们是什么并自行解码/编码.>为了实现动态合成,Hector将其他类型数据写入字节数组,以便它在读取字节时知道如何解码字节.由于没有类型信息,静态合成无法执行此操作.