在Cassandra术语中,什么是TimeUUID?

时间:2010-04-10 17:09:35

标签: cassandra timeuuid

在Cassandra术语中,TimeUUID是什么以及何时使用?

3 个答案:

答案 0 :(得分:12)

TimeUUID是随机的全局唯一标识符。 16个字节。

示例十六进制演示文稿:a4a70900-24e1-11df-8924-001ff3591711

请参阅http://en.wikipedia.org/wiki/Universally_Unique_Identifier

它可以作为关系数据库的主键,或者当您需要在某个键下存储值列表时。

例如,请查看基于cassandra的这个开源Twitter示例:

http://twissandra.com/

http://github.com/ericflo/twissandra

User = {
    'a4a70900-24e1-11df-8924-001ff3591711': {
        'id': 'a4a70900-24e1-11df-8924-001ff3591711',
        'username': 'ericflo',
        'password': '****',
    },
}

Username = {
    'ericflo': {
        'id': 'a4a70900-24e1-11df-8924-001ff3591711',
    },
}

Friends = {
    'a4a70900-24e1-11df-8924-001ff3591711': {
        # friend id: timestamp of when the friendship was added
        '10cf667c-24e2-11df-8924-001ff3591711': '1267413962580791',
        '343d5db2-24e2-11df-8924-001ff3591711': '1267413990076949',
        '3f22b5f6-24e2-11df-8924-001ff3591711': '1267414008133277',
    },
}

此处为用户分配了一个唯一密钥a4a70900-24e1-11df-8924-001ff3591711,用于指代其他地方的用户。

答案 1 :(得分:8)

TimeUUID是抽象类AbstractType的六个具体实现之一。

对于ColumnFamilies,您可以指定名为CompareWith的属性。 (SuperColumns具有类似的CompareSubcolumnsWith属性)。

此属性的有效值是实现抽象类AbstractType的类(例如,TimeUUID)。 CompareWith属性告诉Cassandra如何对列进行排序以进行切片操作。

如果您使用的是Java并使用带有TimeUUID的cassandra,我建议您阅读this section of the cassandra FAQ

答案 2 :(得分:-2)

表示ColumnFamily中唯一的“行”