Package org.eclipse.rdf4j.federated.util
Class QueryStringUtil
java.lang.Object
org.eclipse.rdf4j.federated.util.QueryStringUtil
Various static functions for query handling and parsing.
- Author:
- Andreas Schwarte
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final IRIA dummy URI which is used as a replacement forBNodes inappendBNode(StringBuilder, BNode)since BNodes cannot be expressed in SPARQL queries
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected static StringBuilderappendBNode(StringBuilder sb, BNode bNode) Append a dummy string (seeBNODE_URI) to represent the BNode.protected static StringBuilderappendLiteral(StringBuilder sb, Literal lit) Append the literal to the stringbuilder.protected static StringBuilderappendURI(StringBuilder sb, IRI uri) Append the uri to the stringbuilder, i.e.protected static StringBuilderappendValue(StringBuilder sb, Value value) Append a string representation of the value to the string builder.protected static StringBuilderappendVar(StringBuilder sb, Var var, Set<String> varNames, BindingSet bindings) Append the variable to the provided StringBuilder.protected static StringBuilderappendVarId(StringBuilder sb, Var var, String varID, Set<String> varNames, BindingSet bindings) Append the variable to the provided StringBuilder, however change name of variable by appending "_varId" to it.static StringaskQueryString(ExclusiveTupleExpr expr, BindingSet bindings, Dataset dataset) Transform theExclusiveTupleExprinto a ASK query stringstatic StringaskQueryString(StatementPattern stmt, BindingSet bindings, Dataset dataset) Construct a boolean ASK query for the provided statement.protected static StringconstructInnerUnion(StatementPattern stmt, int outerID, Set<String> varNames, List<BindingSet> bindings) protected static StringconstructJoinArg(ExclusiveTupleExpr exclusiveExpr, Set<String> varNames, BindingSet bindings) Construct a query substring from theExclusiveTupleExprthat can be used as an argument to aJoin.protected static StringconstructStatement(StatementPattern stmt, Set<String> varNames, BindingSet bindings) Construct the statement string, i.e.protected static StringconstructStatementCheckId(StatementPattern stmt, int varID, Set<String> varNames, BindingSet bindings) Construct the statement string, i.e.protected static StringconstructStatementId(StatementPattern stmt, String varID, Set<String> varNames, BindingSet bindings) Construct the statement string, i.e.protected static StringgetValueString(Value value) Return the string representation of this value, seeappendValue(StringBuilder, Value)for details.static booleanhasFreeVars(StatementPattern stmt, BindingSet bindings) returns true iff there is at least one free variable, i.e.loadQueries(String queryFile) load the queries from a queries file located at the specified path.static StringselectQueryString(ExclusiveGroup group, BindingSet bindings, FilterValueExpr filterExpr, AtomicBoolean evaluated, Dataset dataset) Construct a SELECT query for the providedExclusiveGroup.static StringselectQueryString(ExclusiveTupleExprRenderer expr, BindingSet bindings, FilterValueExpr filterExpr, AtomicBoolean evaluated, Dataset dataset) Construct a SELECT query for the providedExclusiveTupleExprRendererstatic StringselectQueryString(StatementPattern stmt, BindingSet bindings, FilterValueExpr filterExpr, AtomicBoolean evaluated, Dataset dataset) Construct a SELECT query for the provided statement.static StringselectQueryStringBoundCheck(StatementPattern stmt, List<BindingSet> unionBindings, Dataset dataset) Construct a SELECT query for a grouped bound check.static StringselectQueryStringBoundJoinVALUES(StatementPattern stmt, List<BindingSet> unionBindings, FilterValueExpr filterExpr, AtomicBoolean evaluated, Dataset dataset) Creates a bound join subquery using the SPARQL 1.1 VALUES operator.static StringselectQueryStringBoundUnion(StatementPattern stmt, List<BindingSet> unionBindings, FilterValueExpr filterExpr, Boolean evaluated, Dataset dataset) Deprecated.static StringselectQueryStringLimit1(ExclusiveGroup group, BindingSet bindings, Dataset dataset) Construct a SELECT query for the providedExclusiveGroupwith LIMIT 1.static StringselectQueryStringLimit1(ExclusiveTupleExpr expr, BindingSet bindings, Dataset dataset) Construct a SELECT query for the provided expr with LIMIT 1.static StringselectQueryStringLimit1(StatementPattern stmt, BindingSet bindings, Dataset dataset) Construct a SELECT query for the provided statement with LIMIT 1.static StringReturn a string representation of this statement using the following pattern, where variables are indicated using ?var and values are represented as strings.static StringtoString(ArbitraryLengthPath node, Set<String> varNames, BindingSet bindings) Converts anArbitraryLengthPathnode to a sub query string and makes sure to insert any bindings.static StringtoString(StatementPattern stmt) Return a string representation of this statement using the following pattern, where variables are indicated using ?var and values are represented as strings.static String
- 
Field Details- 
BNODE_URIA dummy URI which is used as a replacement forBNodes inappendBNode(StringBuilder, BNode)since BNodes cannot be expressed in SPARQL queries
 
- 
- 
Constructor Details- 
QueryStringUtilpublic QueryStringUtil()
 
- 
- 
Method Details- 
hasFreeVarsreturns true iff there is at least one free variable, i.e. there is no binding for any variable- Parameters:
- stmt-
- bindings-
- Returns:
- whether free vars are available
 
- 
toStringReturn a string representation of this statement using the following pattern, where variables are indicated using ?var and values are represented as strings. Pattern: {s; p; o}- Parameters:
- stmt-
- Returns:
- a string representation of the statement
 
- 
toStringConverts anArbitraryLengthPathnode to a sub query string and makes sure to insert any bindings.This method assumes that the ArbitraryLengthPath.getPathExpression()is aStatementPattern.- Parameters:
- node-
- varNames-
- bindings-
- Returns:
- the query string
 
- 
toString
- 
toStringReturn a string representation of this statement using the following pattern, where variables are indicated using ?var and values are represented as strings. Pattern: {s; p; o}- Parameters:
- subj- the subject
- pred- the predicate
- obj- the object
- Returns:
- a string representation
 
- 
selectQueryStringpublic static String selectQueryString(StatementPattern stmt, BindingSet bindings, FilterValueExpr filterExpr, AtomicBoolean evaluated, Dataset dataset) throws IllegalQueryException Construct a SELECT query for the provided statement.- Parameters:
- stmt-
- bindings-
- filterExpr-
- evaluated- parameter can be used outside this method to check whether FILTER has been evaluated, false in beginning
- Returns:
- the SELECT query
- Throws:
- IllegalQueryException- if the query does not have any free variables
 
- 
selectQueryStringpublic static String selectQueryString(ExclusiveTupleExprRenderer expr, BindingSet bindings, FilterValueExpr filterExpr, AtomicBoolean evaluated, Dataset dataset) throws IllegalQueryException Construct a SELECT query for the providedExclusiveTupleExprRenderer- Parameters:
- stmt-
- bindings-
- filterExpr-
- evaluated- parameter can be used outside this method to check whether FILTER has been evaluated, false in beginning
- Returns:
- the SELECT query
- Throws:
- IllegalQueryException- if the query does not have any free variables
 
- 
selectQueryStringpublic static String selectQueryString(ExclusiveGroup group, BindingSet bindings, FilterValueExpr filterExpr, AtomicBoolean evaluated, Dataset dataset) throws IllegalQueryException Construct a SELECT query for the providedExclusiveGroup. Note that bindings and filterExpr are applied whenever possible.- Parameters:
- group- the expression for the query
- bindings- the bindings to be applied
- filterExpr- a filter expression or null
- evaluated- parameter can be used outside this method to check whether FILTER has been evaluated, false in beginning
- Returns:
- the SELECT query string
- Throws:
- IllegalQueryException
 
- 
askQueryStringTransform theExclusiveTupleExprinto a ASK query string- Parameters:
- expr-
- bindings-
- Returns:
- the ASK query string
- Throws:
- IllegalQueryException
 
- 
selectQueryStringBoundUnion@Deprecated public static String selectQueryStringBoundUnion(StatementPattern stmt, List<BindingSet> unionBindings, FilterValueExpr filterExpr, Boolean evaluated, Dataset dataset) Deprecated.replaced with#selectQueryStringBoundJoinVALUES(StatementPattern, List, FilterValueExpr, AtomicBoolean)Construct a SELECT query string for a bound union. Pattern: SELECT ?v_1 ?v_2 ?v_N WHERE { { ?v_1 p o } UNION { ?v_2 p o } UNION ... } Note that the filterExpr is not evaluated at the moment.- Parameters:
- stmt-
- unionBindings-
- filterExpr-
- evaluated- parameter can be used outside this method to check whether FILTER has been evaluated, false in beginning
- Returns:
- the SELECT query string
 
- 
selectQueryStringBoundJoinVALUESpublic static String selectQueryStringBoundJoinVALUES(StatementPattern stmt, List<BindingSet> unionBindings, FilterValueExpr filterExpr, AtomicBoolean evaluated, Dataset dataset) Creates a bound join subquery using the SPARQL 1.1 VALUES operator.Example subquery: SELECT ?v ?__index WHERE { VALUES (?s ?__index) { (:s1 1) (:s2 2) ... (:sN N) } ?s name ?v. }- Parameters:
- stmt-
- unionBindings-
- filterExpr-
- evaluated- parameter can be used outside this method to check whether FILTER has been evaluated, false in beginning
- Returns:
- the SELECT query string
- Since:
- 3.0
- See Also:
 
- 
selectQueryStringBoundCheckpublic static String selectQueryStringBoundCheck(StatementPattern stmt, List<BindingSet> unionBindings, Dataset dataset) Construct a SELECT query for a grouped bound check. Pattern: SELECT ?o_1 .. ?o_N WHERE { { s1 p1 ?o_1 FILTER ?o_1=o1 } UNION ... UNION { sN pN ?o_N FILTER ?o_N=oN }}- Parameters:
- stmt-
- unionBindings-
- Returns:
- the SELECT query string
 
- 
constructInnerUnionprotected static String constructInnerUnion(StatementPattern stmt, int outerID, Set<String> varNames, List<BindingSet> bindings) 
- 
constructJoinArgprotected static String constructJoinArg(ExclusiveTupleExpr exclusiveExpr, Set<String> varNames, BindingSet bindings) Construct a query substring from theExclusiveTupleExprthat can be used as an argument to aJoin.This method can only be used for ExclusiveTupleExprthat additionally provideExclusiveTupleExprRenderercapabilities. An exception to this is if the given expression is aStatementPattern, e.g. anExclusiveStatementorExclusiveGroup.- Parameters:
- exclusiveExpr-
- varNames-
- bindings-
- Returns:
- the query string with bindings inserted
 
- 
askQueryStringConstruct a boolean ASK query for the provided statement.- Parameters:
- stmt-
- bindings-
- Returns:
- the ASK query string
 
- 
selectQueryStringLimit1public static String selectQueryStringLimit1(StatementPattern stmt, BindingSet bindings, Dataset dataset) Construct a SELECT query for the provided statement with LIMIT 1. Such query can be used for source selection instead of ASK queries.- Parameters:
- stmt-
- bindings-
- Returns:
- the SELECT query string
 
- 
selectQueryStringLimit1public static String selectQueryStringLimit1(ExclusiveTupleExpr expr, BindingSet bindings, Dataset dataset) Construct a SELECT query for the provided expr with LIMIT 1. Such query can be used for source selection instead of ASK queries.- Parameters:
- stmt-
- bindings-
- Returns:
- the SELECT query string
 
- 
selectQueryStringLimit1public static String selectQueryStringLimit1(ExclusiveGroup group, BindingSet bindings, Dataset dataset) Construct a SELECT query for the providedExclusiveGroupwith LIMIT 1. Such query can be used for source selection instead of ASK queries.- Parameters:
- group-
- bindings-
- Returns:
- the SELECT query string
 
- 
constructStatementprotected static String constructStatement(StatementPattern stmt, Set<String> varNames, BindingSet bindings) Construct the statement string, i.e. "s p o . " with bindings inserted wherever possible. Note that the relevant free variables are added to the varNames set for further evaluation.- Parameters:
- stmt-
- varNames-
- bindings-
- Returns:
- the constructed statement pattern
 
- 
constructStatementIdprotected static String constructStatementId(StatementPattern stmt, String varID, Set<String> varNames, BindingSet bindings) Construct the statement string, i.e. "s p o . " with bindings inserted wherever possible. Variables are renamed to "var_"+varId to identify query results in bound queries. Note that the free variables are also added to the varNames set for further evaluation.- Parameters:
- stmt-
- varNames-
- bindings-
- Returns:
- the constructed statement pattern
 
- 
constructStatementCheckIdprotected static String constructStatementCheckId(StatementPattern stmt, int varID, Set<String> varNames, BindingSet bindings) Construct the statement string, i.e. "s p ?o_varID FILTER ?o_N=o ". This kind of statement pattern is necessary to later on identify available results.- Parameters:
- stmt-
- varID-
- varNames-
- bindings-
- Returns:
- the statement pattern string
 
- 
appendVarprotected static StringBuilder appendVar(StringBuilder sb, Var var, Set<String> varNames, BindingSet bindings) Append the variable to the provided StringBuilder. Cases: 1) unbound: check provided bindingset for possible match a) match found: append matching value b) no match: append ?varName and add to varNames 2) bound: append value- Parameters:
- sb-
- var-
- varNames-
- bindings-
- Returns:
- the stringbuilder
 
- 
appendVarIdprotected static StringBuilder appendVarId(StringBuilder sb, Var var, String varID, Set<String> varNames, BindingSet bindings) Append the variable to the provided StringBuilder, however change name of variable by appending "_varId" to it. Cases: 1) unbound: check provided bindingset for possible match a) match found: append matching value b) no match: append ?varName_varId and add to varNames 2) bound: append value- Parameters:
- sb-
- var-
- varNames-
- bindings-
- Returns:
- the complemented string builder
 
- 
getValueStringReturn the string representation of this value, seeappendValue(StringBuilder, Value)for details.- Parameters:
- value-
- Returns:
- the string representation
 
- 
appendValueAppend a string representation of the value to the string builder. 1. URI: <http://myUri> 2. Literal: "myLiteral"^^- Parameters:
- sb-
- value-
- Returns:
- the string builder
 
- 
appendURIAppend the uri to the stringbuilder, i.e. <uri.stringValue>.- Parameters:
- sb-
- uri-
- Returns:
- the string builder
 
- 
appendBNodeAppend a dummy string (seeBNODE_URI) to represent the BNode. Note: currently it is not possible to retrieve values for a BNode via SPARQL, hence we use a dummy BNode which does not produce any results. A warning is printed to debug.- Parameters:
- sb-
- bNode-
- Returns:
- the string builder
 
- 
appendLiteralAppend the literal to the stringbuilder.- Parameters:
- sb-
- lit-
- Returns:
- the string builder
 
- 
loadQueriesload the queries from a queries file located at the specified path. Expected format: - Queries are SPARQL queries in String format - queries are allowed to span several lines - a query is interpreted to be finished if an empty line occurs Ex: QUERY1 ... Q1 cntd QUERY2- Parameters:
- queryFile-
- Returns:
- a list of queries for the query type
- Throws:
- FileNotFoundException
- IOException
 
 
- 
#selectQueryStringBoundJoinVALUES(StatementPattern, List, FilterValueExpr, AtomicBoolean)