我想将多个对象插入到一个三元组存储中,比如Jena、fuseki或virtuoso。
在我的例子中,主题等于一个主键。它类似于关系数据库。如何确保主题只出现一次或已在使用中?在Sparql中,ASK可以与insert结合使用吗?或者可以生成密钥?
只要您使用后端的一个实例,您就可以确保主题只存在一次,但是如果有更多的实例,则必须同时执行查询和插入才能保存事务。
发布于 2019-02-08 23:34:22
更新可以是INSERT .. WHERE形式,并且WHERE部件可以包括是否更新的测试。
用于更新的SPARQL协议要求操作是原子的。
发布于 2019-02-08 05:15:31
SPARQL标准本身不提供对事务的任何支持。但是,Virtuoso和许多其他RDF都支持完全支持事务的Eclipse RDF4J API(披露:我是RDF4J开发团队的成员)。在Java中使用RDF4J事务的示例如下所示:
Repository rep = ... ; // the Repository object is your database
// open a connection to the database
try(RepositoryConnection conn = rep.getConnection) {
conn.begin(); // start a new transaction
...
// do a query
boolean success = conn.prepareBooleanQuery("ASK ...").evaluate();
if (!success) {
conn.rollback();
}
else {
// add some data
conn.add(...);
conn.commit();
}
}有关事务如何使用RDF4J的更多信息,请参阅documentation。
如果您不使用Java语言,也可以通过RDF4J REST API处理事务,它是SPARQL协议的一个扩展。
顺便说一句:上面只是回答了你的问题中“我该如何处理事务”这一部分。对于您正在寻找的那种约束验证,可能还有其他更好的机制,而不是执行ASK查询。SHACL,形状约束语言,可能就是您需要的。各种工具和平台都(部分或全部)支持SHACL验证。你可以在这里阅读更多关于RDF4J SHACL support的内容。
https://stackoverflow.com/questions/54581081
复制相似问题