rdflib图未更新。为什么?

时间:2009-12-07 14:24:21

标签: python rdf rdflib

我试图理解这种行为。这绝对不是我的期望。我有两个程序,一个读者和一个作家。阅读器打开RDFlib图形存储,然后每2秒执行一次查询

import rdflib
import random
from rdflib import store
import time

default_graph_uri = "urn:uuid:a19f9b78-cc43-4866-b9a1-4b009fe91f52"

s = rdflib.plugin.get('MySQL', store.Store)('rdfstore')

config_string = "host=localhost,password=foo,user=foo,db=foo"
rt = s.open(config_string,create=False)
if rt != store.VALID_STORE:
    s.open(config_string,create=True)


while True:
    graph = rdflib.ConjunctiveGraph(s, identifier = rdflib.URIRef(default_graph_uri))
    rows = graph.query("SELECT ?id ?value { ?id <http://localhost#ha> ?value . }")
    for r in rows:
        print r[0], r[1]
    time.sleep(2)
    print " - - - - - - - - "

第二个程序是一个将内容添加到triplestore

的编写器
import rdflib
import random
from rdflib import store

default_graph_uri = "urn:uuid:a19f9b78-cc43-4866-b9a1-4b009fe91f52"

s = rdflib.plugin.get('MySQL', store.Store)('rdfstore')

config_string = "host=localhost,password=foo,user=foo,db=foo"
rt = s.open(config_string,create=False)
if rt != store.VALID_STORE:
    s.open(config_string,create=True)

graph = rdflib.ConjunctiveGraph(s, identifier = rdflib.URIRef(default_graph_uri))

graph.add( ( 
            rdflib.URIRef("http://localhost/"+str(random.randint(0,100))), 
            rdflib.URIRef("http://localhost#ha"),
            rdflib.Literal(str(random.randint(0,100)))
            ) 
            )
graph.commit()

当我使用编写器提交内容时,我希望看到读取器上的结果数量增加,但这不会发生。读者继续返回与开始时相同的结果。但是,如果我停止阅读器并重新启动它,则会显示新结果。

有人知道我做错了什么吗?

1 个答案:

答案 0 :(得分:3)

一个简单的解决方法是在阅读器中的“graph = rdflib.ConjunctiveGraph(...)”行之后放置“graph.commit()”。 我不确定是什么原因以及为什么在阅读之前提交修复此问题。我猜测

  • 打开MySQLdb连接时,会自动启动一个事务
  • 此交易未看到其他以后的交易的更新。
  • “graph.commit()”冒泡到一些“connection.commit()”某处丢弃此交易并启动一个新交易。