在Cassandra术语中,TimeUUID
是什么以及何时使用?
答案 0 :(得分:12)
TimeUUID是随机的全局唯一标识符。 16个字节。
示例十六进制演示文稿:a4a70900-24e1-11df-8924-001ff3591711
请参阅http://en.wikipedia.org/wiki/Universally_Unique_Identifier
它可以作为关系数据库的主键,或者当您需要在某个键下存储值列表时。
例如,请查看基于cassandra的这个开源Twitter示例:
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中唯一的“行”