4

我刚刚开始在 Cassandra 上使用 Titan。我是 Titan 的新手,也是图形数据库概念的新手。只需按照 github 和 wiki 上的说明进行操作。

Configuration conf = new BaseConfiguration();
conf.setProperty("storage.backend", "cassandra");
conf.setProperty("storage.hostname", "127.0.0.1");
TitanGraph g = TitanFactory.open(conf);

这就是我打开图表的方式。

我知道默认键空间是titan. 我在默认键空间中创建了一些节点和关系。我对顶点进行了索引并查询了节点并能够遍历结果。

现在我的问题 -

1)如何设置新的密钥空间?

我尝试使用该属性

conf.setProperty("storage.keyspace ", "newkeyspace");

不幸的是,当我检查 cassandra 键空间时,我只能找到titan. 名称中没有键空间newkeyspace。可能是什么原因?

2)如何持久化已创建的图表?

例如,

g.createKeyIndex("name", Vertex.class);
Vertex juno = g.addVertex(null);
juno.setProperty("name", "juno");
juno.setProperty("type", "node");
Vertex juno1 = g.addVertex(null);
juno1.setProperty("name", "juno");
juno1.setProperty("type", "node1");

这是一个示例图。一旦我发出表格查询

Iterator<Vertex> junoIterator = g.getVertices("name", "juno")
                .iterator();
        while (junoIterator.hasNext()) {
            Vertex vertex = (Vertex) junoIterator.next();
            System.out.println(vertex.getProperty("type"));
        }

我的预期结果是

node 
node1

一旦我评论以下部分,相同的查询应该可以正常工作 -

    /*g.createKeyIndex("name", Vertex.class);
        Vertex juno = g.addVertex(null);
        juno.setProperty("name", "juno");
        juno.setProperty("type", "node");
        Vertex juno1 = g.addVertex(null);
        juno1.setProperty("name", "juno");
        juno1.setProperty("type", "node1");*/

在这里,我相信节点、关系和索引已经构建并保存在某个数据存储中。我有错误的信念吗?

请指教。

4

2 回答 2

3

我已经弄清楚了这个问题。只是一个承诺的问题。

一条线g.commit();解决了所有问题。

于 2013-08-16T13:56:29.067 回答
0

要创建一个新的 Titan 表(cassandra 中的键空间),请使用以下属性:

set("storage.cassandra.keyspace","TitanTest")

整个命令就像:

图 = TitanFactory.build()。设置(“存储。后端”,“卡桑德拉”)。set("storage.hostname","127.0.0.1").set("index.search.backend","elasticsearch").set("storage.cassandra.astyanax.cluster-name","Test Cluster")。 set("storage.cassandra.keyspace","TitanTest").set("cache.db-cache","true").open();

于 2016-04-12T09:09:49.713 回答