加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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将其他类型数据写入字节数组,以便它在读取字节时知道如何解码字节.由于没有类型信息,静态合成无法执行此操作.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读