尝试从 CONSTRUCT 查询异常中获取 ResultSet

Posted

技术标签:

【中文标题】尝试从 CONSTRUCT 查询异常中获取 ResultSet【英文标题】:Attempt to have ResultSet from a CONSTRUCT query Exception 【发布时间】:2011-08-04 11:04:11 【问题描述】:

我正在尝试使用以下查询:

QUERY="PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#> \n" +
            " PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> \n" +
                    "CONSTRUCT  \n" +
    "?cls ?cp ?co . \n" +
   " ?prop ?pp ?po . \n" +
"" +
"WHERE  \n" +
    "?cls a rdfs:Class . \n" + 
    "?cls ?cp ?co .  \n" +
    "?prop a rdf:Property . \n" +
    "?prop ?pp ?po .  \n " + 
"";

results = qe.execSelect();

查询在字符串变量 QUERY 中。 我正在使用耶拿 整个事情都在一个有 2 个按钮的界面中。 QUERY 在用户单击 button1 时进行选择查询,如果用户单击 button2,则进行上述查询

如果 QUERY 同时包含构造和选择,则会出现以下异常 线程“AWT-EventQueue-0”com.hp.hpl.jena.query.QueryExecException 中的异常:尝试从 CONSTRUCT 查询中获取 ResultSet 在 com.hp.hpl.jena.sparql.engine.QueryExecutionBase.execSelect(QueryExecutionBase.java:93)

【问题讨论】:

【参考方案1】:

CONSTRUCT 查询生成模型,而不是结果集。你需要使用:

Model model = qe.execConstruct();

您不能有一个“同时包含构造和选择”的查询。 (除非您的意思是包含子选择的构造?)

您可能会发现以下内容很有用:

Query q = QueryFactory.create(QUERY);

if (q.isSelectType())  ... execSelect, deal with results ... 
else if (q.isConstructType())  ... execConstruct, deal with result model ... 
else  ... do you deal with DESCRIBE? ... 

【讨论】:

以上是关于尝试从 CONSTRUCT 查询异常中获取 ResultSet的主要内容,如果未能解决你的问题,请参考以下文章

从 CriteriaQuery 获取列表时出现异常

无法从 sveltekit 循环中的 JSON 对象获取值

android.content.res.Resources$NotFoundException: Main 中的字符串资源 ID 致命异常

创建查询以在对象数组中查找对象[重复]

创建查询以在对象数组中查找对象[重复]

从 SQL 失败中获取表