當前位置: 首頁>>代碼示例>>Java>>正文


Java Expression類代碼示例

本文整理匯總了Java中de.fuberlin.wiwiss.d2rq.expr.Expression的典型用法代碼示例。如果您正苦於以下問題:Java Expression類的具體用法?Java Expression怎麽用?Java Expression使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Expression類屬於de.fuberlin.wiwiss.d2rq.expr包,在下文中一共展示了Expression類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: selectNode

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
public NodeMaker selectNode(Node node, RelationalOperators sideEffects) {
	if (node.equals(Node.ANY) || node.isVariable()) {
		return this;
	}
	if (!this.nodeType.matches(node)) {
		return NodeMaker.EMPTY;
	}
	String value = this.nodeType.extractValue(node);
	if (value == null) {
		return NodeMaker.EMPTY;
	}
	Expression expr = valueMaker.valueExpression(value);
	if (expr.isFalse()) {
		sideEffects.select(Expression.FALSE);
		return NodeMaker.EMPTY;
	}
	sideEffects.select(expr);
	return new FixedNodeMaker(node, isUnique());
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:20,代碼來源:TypedNodeMaker.java

示例2: matchPatterns

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
private List<Expression> matchPatterns(Pattern p1, Pattern p2) {
	List<Expression> results = new ArrayList<Expression>(p1.attributes().size());
	if (p1.isEquivalentTo(p2)) {
		for (int i = 0; i < p1.attributes().size(); i++) {
			Attribute col1 = p1.attributes().get(i);
			Attribute col2 = p2.attributes().get(i);
			results.add(Equality.createAttributeEquality(col1, col2));
		}
	} else {
		results.add(Equality.create(p1.toExpression(), p2.toExpression()));
		// FIXME: Actually support it
		if (p1.usesColumnFunctions() || p2.usesColumnFunctions()) {
			log.warn("Joining multiple d2rq:[uri]Patterns with different @@|[email protected]@ is not supported");
			unsupported = true;
		}
	}
	return results;
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:19,代碼來源:NodeSetConstraintBuilder.java

示例3: valueExpression

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
public Expression valueExpression(String value) {
	if (value == null) {
		return Expression.FALSE;
	}
	Matcher match = this.regex.matcher(value);
	if (!match.matches()) {
		return Expression.FALSE;
	}
	Collection<Expression> expressions = new ArrayList<Expression>(columns.size());
	for (int i = 0; i < this.columns.size(); i++) {
		Attribute attribute = columns.get(i);
		ColumnFunction function = columnFunctions.get(i);
		String attributeValue = function.decode(match.group(i + 1));
		if (attributeValue == null) {
			return Expression.FALSE;
		}
		expressions.add(Equality.createAttributeValue(attribute, attributeValue));
	}
	return Conjunction.create(expressions);
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:21,代碼來源:Pattern.java

示例4: valueExpression

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
public Expression valueExpression(String value) {
	if (value == null) {
		return Expression.FALSE;
	}
	String[] parts = value.split(DELIMITER);
	// Check if given bNode was created by this class map
	if (parts.length != this.attributes.size() + 1 
			|| !this.classMapID.equals(parts[0])) {
		return Expression.FALSE;		
	}
	int i = 1;	// parts[0] is classMap identifier
	Collection<Expression> expressions = new ArrayList<Expression>(attributes.size());
	for (Attribute attribute: attributes) {
		expressions.add(Equality.createAttributeValue(attribute, parts[i]));
		i++;
	}
	return Conjunction.create(expressions);
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:19,代碼來源:BlankNodeID.java

示例5: visit

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
public void visit(ExprVar var)
{
	logger.debug("visit ExprVar " + var);
	
	if (!convertable) {
		expression.push(Expression.FALSE); // prevent stack empty exceptions when conversion
		return;                            // fails in the middle of a multi-arg operator conversion
	}
	
	String varName = var.getVarName();
	
	// if expression contains a blank node, no conversion to sql can be done
	if (Var.isBlankNodeVarName(varName)) {
		conversionFailed("blank nodes not supported", var);
		return;
	}
	
	List<Expression> expressions = toExpression(var);
	if (expressions.size() == 1) {
		expression.push(expressions.get(0));
	} else {
		// no single sql-column for sparql-var does exist break up conversion
		// (the case for Pattern ValueMakers)
		conversionFailed("multi column pattern valuemakers not supported", var);
	}
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:27,代碼來源:TransformExprToSQLApplyer.java

示例6: visitExprFunction

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
private void visitExprFunction(ExprFunction function)
{
	logger.debug("visit ExprFunction " + function);
	
	if (!convertable) {
		expression.push(Expression.FALSE); // prevent stack empty exceptions when conversion
		return;                            // fails in the middle of a multi-arg operator conversion
	}
	if (!extensionSupports(function)) {
		conversionFailed(function);
		return;
	}
	
	for (int i = 0; i < function.numArgs(); i++)
		function.getArg(i + 1).visit(this);
	List<Expression> args = new ArrayList<Expression>(function.numArgs());
	
	for (int i = 0; i < function.numArgs(); i++)
		args.add(expression.pop());
	Collections.reverse(args);
	extensionConvert(function, args);
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:23,代碼來源:TransformExprToSQLApplyer.java

示例7: convertIsIRI

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
private void convertIsIRI(E_IsIRI expr)
{
	logger.debug("convertIsIRI " + expr.toString());
	
	expr.getArg().visit(this);
	
	Expression arg = expression.pop();
	
	if (arg instanceof AttributeExprEx) {
		AttributeExprEx variable = (AttributeExprEx) arg;
		NodeMaker nm = variable.getNodeMaker();
		DetermineNodeType filter = new DetermineNodeType();
		nm.describeSelf(filter);
		expression.push(filter.isLimittedToURIs() ? Expression.TRUE : Expression.FALSE);
	} else if (arg instanceof ConstantEx) {
		ConstantEx constant = (ConstantEx) arg;
		Node node = constant.getNode();
		expression.push(node.isURI() ? Expression.TRUE : Expression.FALSE);
	} else {
		conversionFailed(expr);
	}
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:23,代碼來源:TransformExprToSQLApplyer.java

示例8: convertIsBlank

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
private void convertIsBlank(E_IsBlank expr)
{
	logger.debug("convertIsBlank " + expr.toString());
	
	expr.getArg().visit(this);
	
	Expression arg = expression.pop();
	
	if (arg instanceof AttributeExprEx) {
		AttributeExprEx variable = (AttributeExprEx) arg;
		NodeMaker nm = variable.getNodeMaker();
		DetermineNodeType filter = new DetermineNodeType();
		nm.describeSelf(filter);
		expression.push(filter.isLimittedToBlankNodes() ? Expression.TRUE : Expression.FALSE);
	} else if (arg instanceof ConstantEx) {
		ConstantEx constant = (ConstantEx) arg;
		Node node = constant.getNode();
		expression.push(node.isBlank() ? Expression.TRUE : Expression.FALSE);
	} else {
		conversionFailed(expr);
	}
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:23,代碼來源:TransformExprToSQLApplyer.java

示例9: testDataType

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
public void testDataType()
{
	List<Triple> pattern = new ArrayList<Triple>();
	pattern.add(Triple.create(Node.createVariable("s"), Node.createURI("http://example.org/value"), Node.createVariable("o")));
	NodeRelation[] rels = translate(pattern, "optimizer/filtertests.n3");
	
	NodeRelation intvalue = search("table2", "intvalue", rels);
	NodeRelation value = search("table2", "value", rels);
	
	pattern.clear();
	pattern.add(Triple.create(Node.createVariable("s"), RDFS.label.asNode(), Node.createVariable("o")));
	rels = translate(pattern, "optimizer/filtertests.n3");
	
	NodeRelation langliteral = search("table1", "label_en", rels);
	
	Expr filterint    = new E_Equals(new E_Datatype(new ExprVar("o")), NodeValueNode.makeNode(Node.createURI(XSDDatatype.XSDint.getURI())));
	Expr filterstring = new E_Equals(new E_Datatype(new ExprVar("o")), NodeValueNode.makeNode(Node.createURI(XSDDatatype.XSDstring.getURI())));
	
	assertEquals("DATATYPE(intliteral) = xsd:int should be TRUE",       Expression.TRUE, TransformExprToSQLApplyer.convert(filterint, intvalue));
	assertEquals("DATATYPE(simpleliteral) = xsd:string should be TRUE", Expression.TRUE, TransformExprToSQLApplyer.convert(filterstring, value));
	assertEquals("DATATYPE(langliteral) = xsd:string should be TRUE",   Expression.TRUE, TransformExprToSQLApplyer.convert(filterstring, langliteral));
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:23,代碼來源:ExprTransformTest2.java

示例10: convertLangMatches

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
private void convertLangMatches(E_LangMatches expr)
{
	logger.debug("convertLangMatches " + expr.toString());
	
	expr.getArg1().visit(this);
	expr.getArg2().visit(this);
	Expression e2 = expression.pop();
	Expression e1 = expression.pop();
	
	if (e1 instanceof ConstantEx && e2 instanceof ConstantEx) {
		ConstantEx lang1 = (ConstantEx) e1;
		ConstantEx lang2 = (ConstantEx) e2;
		NodeValue nv1 = NodeValue.makeString(lang1.getNode().getLiteral().getLexicalForm());
		NodeValue nv2 = NodeValue.makeString(lang2.getNode().getLiteral().getLexicalForm());
		NodeValue match = NodeFunctions.langMatches(nv1, nv2);
		expression.push(match.equals(NodeValue.TRUE) ? Expression.TRUE : Expression.FALSE);
	} else {
		expression.push(Expression.FALSE);
	}
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:21,代碼來源:TransformExprToSQLApplyer.java

示例11: testLang

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
public void testLang()
{
	List<Triple> pattern = new ArrayList<Triple>();
	pattern.add(Triple.create(Node.createVariable("s"), RDFS.label.asNode(), Node.createVariable("o")));
	NodeRelation[] rels = translate(pattern, "optimizer/filtertests.n3");
	
	NodeRelation label_fr_be  = search("table1", "label_fr_be", rels);
	NodeRelation label_en     = search("table1", "label_en", rels);
	NodeRelation label_noLang = search("table1", "label", rels);
	
	Expr filterFR    = new E_Equals(new E_Lang(new ExprVar("o")), NodeValue.makeString("fr"));
	Expr filterEN_TAG_EN = new E_Equals(new E_Lang(new ExprVar("o")), NodeValue.makeNode("en", "en", (String) null));
	Expr filterFR_BE = new E_Equals(new E_Lang(new ExprVar("o")), NodeValue.makeString("fr-BE"));
	Expr filter      = new E_Equals(new E_Lang(new ExprVar("o")), NodeValue.makeString(""));
	
	assertEquals("LANG(label_fr_be) = \"fr\" should be FALSE",   Expression.FALSE, TransformExprToSQLApplyer.convert(filterFR, label_fr_be));
	assertEquals("LANG(label_en) = \"fr\" should be FALSE",      Expression.FALSE, TransformExprToSQLApplyer.convert(filterFR, label_en));
	assertEquals("LANG(label_fr_be) = \"fr_be\" should be TRUE", Expression.TRUE,  TransformExprToSQLApplyer.convert(filterFR_BE, label_fr_be));
	assertEquals("LANG(label_en) = \"en\"@en should be FALSE",   Expression.FALSE, TransformExprToSQLApplyer.convert(filterEN_TAG_EN, label_en));
	assertEquals("LANG(label_noLang) = \"\" should be TRUE",     Expression.TRUE,  TransformExprToSQLApplyer.convert(filter, label_noLang));
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:22,代碼來源:ExprTransformTest2.java

示例12: joinedBaseRelation

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
private Relation joinedBaseRelation() {
	List<Relation> relations = new ArrayList<Relation>();
	for (NodeRelation tripleRelation: joinedTripleRelations) {
		relations.add(tripleRelation.baseRelation());
	}
	return joinRelations(relations, Expression.TRUE);
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:8,代碼來源:TripleRelationJoiner.java

示例13: joinRelations

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
/**
 * Static convenience function that joins several {@link Relation}s into one. Exposed here
 * because it can be used in the old FastPath engine.
 * 
 * @param relations A set of {@link Relation}s
 * @param additionalCondition An additional expression, e.g. join condition
 * @return A relation that is the join of the inputs
 */
private Relation joinRelations(Collection<Relation> relations, Expression additionalCondition) {
	if (relations.isEmpty()) {
		return Relation.TRUE;
	}
	ConnectedDB connectedDB = ((Relation) relations.iterator().next()).database();
	AliasMap joinedAliases = AliasMap.NO_ALIASES;
	Collection<Expression> expressions = new HashSet<Expression>();
	expressions.add(additionalCondition);
	Collection<Expression> softConditions = new HashSet<Expression>();
	Set<Join> joins = new HashSet<Join>();
	Set<ProjectionSpec> projections = new HashSet<ProjectionSpec>();
	int limit = Relation.NO_LIMIT;
	int limitInverse = Relation.NO_LIMIT;
	List<OrderSpec> orderSpecs = null;
	
	for (Relation relation: relations) {
		joinedAliases = joinedAliases.applyTo(relation.aliases());
		expressions.add(relation.condition());
		softConditions.add(relation.softCondition());
		joins.addAll(relation.joinConditions());
		projections.addAll(relation.projections());
		orderSpecs = orderSpecs == null ? relation.orderSpecs() : orderSpecs;
		limit = Relation.combineLimits(limit, relation.limit());
		limitInverse = Relation.combineLimits(limitInverse, relation.limitInverse());
	}
	// TODO: Determine correct uniqueness instead of just false.
	// The new relation is unique if it is joined only on unique node sets.
	// A node set is unique if it is constrained by only unique node makers.
	
	// In the meantime, copy the uniqueness from the relation if there's just one
	boolean isUnique = relations.size() == 1 && (relations.iterator().next()).isUnique();
	return new RelationImpl(connectedDB, joinedAliases, Conjunction.create(expressions), 
			Conjunction.create(softConditions),
			joins, projections, isUnique, orderSpecs, limit, limitInverse);
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:44,代碼來源:TripleRelationJoiner.java

示例14: applyFilter

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
private List<NodeRelation> applyFilter(
		List<NodeRelation> nodeRelations, Expr filter, ExprList allFilters) {
    List<NodeRelation> result = new ArrayList<NodeRelation>();
    boolean convertable = true;
    for (NodeRelation nodeRelation: nodeRelations) {
    	// TODO: The transformation from Expr to Expression should happen in NodeRelation.select()
        Expression expression = TransformExprToSQLApplyer.convert(filter, nodeRelation);
        if (expression == null) {
        	// the expression cannot be transformed to SQL
            convertable = false;
        } else if (expression.isTrue()) {
        	// keep as is
        } else if (expression.isFalse()) {
            continue;	// skip
        } else {
        	nodeRelation = nodeRelation.select(expression);
        	if (nodeRelation.baseRelation().condition().isFalse()) continue;
        }
        result.add(nodeRelation);
    }
    if (convertable) {
    	log.debug("Removing converted filter: " + filter);
        allFilters.getList().remove(filter);
    } else {
    	log.debug("Filter could not be fully converted and is kept: " + filter);
    }
    return result;
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:29,代碼來源:TransformOpBGP.java

示例15: createSimpleRelation

import de.fuberlin.wiwiss.d2rq.expr.Expression; //導入依賴的package包/類
public static Relation createSimpleRelation(
		ConnectedDB database, Attribute[] attributes) {
	return new RelationImpl(database, AliasMap.NO_ALIASES, Expression.TRUE, Expression.TRUE,
			Collections.<Join>emptySet(), 
			new HashSet<ProjectionSpec>(Arrays.asList(attributes)), 
			false, Collections.<OrderSpec>emptyList(), -1, -1);
}
 
開發者ID:aitoralmeida,項目名稱:c4a_data_repository,代碼行數:8,代碼來源:Relation.java


注:本文中的de.fuberlin.wiwiss.d2rq.expr.Expression類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。