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


Java PColFilterExtractor類代碼示例

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


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

示例1: negativeTest

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
private void negativeTest(String query, List<String> partitionCols,
        int expectedErrorCode) throws Exception {
    PigServer pigServer = new PigServer( pc );
    LogicalPlan newLogicalPlan = Util.buildLp(pigServer, query);
    Operator op = newLogicalPlan.getSinks().get(0);
    LOFilter filter = (LOFilter)newLogicalPlan.getPredecessors(op).get(0);
    PColFilterExtractor pColExtractor = new PColFilterExtractor(
            filter.getFilterPlan(), partitionCols);
    try {
        pColExtractor.visit();
    } catch(Exception e) {
        Assert.assertEquals("Checking if exception has right error code",
                expectedErrorCode, LogUtils.getPigException(e).getErrorCode());
        return;
    }
}
 
開發者ID:sigmoidanalytics,項目名稱:spork-streaming,代碼行數:17,代碼來源:TestPartitionFilterPushDown.java

示例2: negativeTest

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
private void negativeTest(String query, List<String> partitionCols,
        int expectedErrorCode) throws Exception {
    PigServer pigServer = new PigServer( pc );
    LogicalPlan newLogicalPlan = Util.buildLp(pigServer, query);
    Operator op = newLogicalPlan.getSinks().get(0);
    LOFilter filter = (LOFilter)newLogicalPlan.getPredecessors(op).get(0);
    PColFilterExtractor pColExtractor = new PColFilterExtractor(
            filter.getFilterPlan(), partitionCols);
    try {
        pColExtractor.visit();
    } catch(Exception e) {
        Assert.assertEquals("Checking if exception has right error code", 
                expectedErrorCode, LogUtils.getPigException(e).getErrorCode());
        return;
    }
}
 
開發者ID:PonIC,項目名稱:PonIC,代碼行數:17,代碼來源:TestPartitionFilterPushDown.java

示例3: transform

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
@Override
    public void transform(OperatorPlan matched) throws FrontendException {
    	subPlan = new OperatorSubPlan( currentPlan );

    	setupColNameMaps();
    	
    	// PIG-1871: Don't throw exception if partition filters cannot be pushed up. 
    	// Perform transformation on a copy of the filter plan, and replace the 
    	// original filter plan only if the transformation is successful 
    	// (i.e. partition filter can be pushed down) 
    	LogicalExpressionPlan filterExpr = loFilter.getFilterPlan();
    	LogicalExpressionPlan filterExprCopy = filterExpr.deepCopy();
    	
    	PColFilterExtractor pColFilterFinder = new PColFilterExtractor(
    	        filterExprCopy, getMappedKeys( partitionKeys ) );
    	pColFilterFinder.visit();
    	Expression partitionFilter = pColFilterFinder.getPColCondition();
    	
    	if(partitionFilter != null) {
    		// the column names in the filter may be the ones provided by
    		// the user in the schema in the load statement - we may need
    		// to replace them with partition column names as given by
    		// LoadFunc.getSchema()
    		updateMappedColNames(partitionFilter);
    		try {
	loadMetadata.setPartitionFilter(partitionFilter);
} catch (IOException e) {
	throw new FrontendException( e );
}
    		if(pColFilterFinder.isFilterRemovable()) {  
    			currentPlan.removeAndReconnect( loFilter );
    		} else {
    		    loFilter.setFilterPlan(filterExprCopy);
    		}
    	}
    }
 
開發者ID:sigmoidanalytics,項目名稱:spork-streaming,代碼行數:37,代碼來源:PartitionFilterOptimizer.java

示例4: testColNameMapping1

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
/**
 * Test that pig sends correct partition column names in setPartitionFilter
 * when the user has a schema in the load statement which renames partition
 * columns
 * @throws Exception
 */
@Test
public void testColNameMapping1() throws Exception {
    TestLoader.partFilter = null;
    String q = "a = load 'foo' using "
        + TestLoader.class.getName() +
        "('srcid:int, mrkt:chararray, dstid:int, name:chararray, age:int', " +
        "'srcid,mrkt') as (f1, f2, f3, f4, f5);" +
        "b = filter a by " +
        "(f5 >= 20 and f2 == 'us') and (f1 == 10 and f3 == 15);" +
        "store b into 'out';";

    LogicalPlan newLogicalPlan = migrateAndOptimizePlan( q );

    Assert.assertEquals("checking partition filter:",
            "((mrkt == 'us') and (srcid == 10))",
            TestLoader.partFilter.toString());
    Operator op = newLogicalPlan.getSinks().get(0);
    LOFilter filter = (LOFilter)newLogicalPlan.getPredecessors(op).get(0);

    PColFilterExtractor extractor = new PColFilterExtractor(filter.getFilterPlan(), new ArrayList<String>());

    String actual = extractor.getExpression(
            (LogicalExpression)filter.getFilterPlan().getSources().get(0)).
            toString().toLowerCase();
    Assert.assertEquals("checking trimmed filter expression:",
            "((f5 >= 20) and (f3 == 15))", actual);
}
 
開發者ID:sigmoidanalytics,項目名稱:spork-streaming,代碼行數:34,代碼來源:TestPartitionFilterPushDown.java

示例5: testColNameMapping2

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
/**
 * Test that pig sends correct partition column names in setPartitionFilter
 * when the user has a schema in the load statement which renames partition
 * columns - in this test case there is no condition on partition columns
 * - so setPartitionFilter() should not be called and the filter condition
 * should remain as is.
 * @throws Exception
 */
@Test
public void testColNameMapping2() throws Exception {
    TestLoader.partFilter = null;
    String q = "a = load 'foo' using "
        + TestLoader.class.getName() +
        "('srcid:int, mrkt:chararray, dstid:int, name:chararray, age:int', " +
        "'srcid') as (f1, f2, f3, f4, f5);" +
        "b = filter a by " +
        "f5 >= 20 and f2 == 'us' and f3 == 15;" +
        "store b into 'out';";

    LogicalPlan newLogicalPlan = migrateAndOptimizePlan( q );

    Assert.assertEquals("checking partition filter:",
            null,
            TestLoader.partFilter);
    Operator op = newLogicalPlan.getSinks().get(0);
    LOFilter filter = (LOFilter)newLogicalPlan.getPredecessors(op).get(0);

    PColFilterExtractor extractor = new PColFilterExtractor(filter.getFilterPlan(), new ArrayList<String>());

    String actual = extractor.getExpression(
            (LogicalExpression) filter.getFilterPlan().
            getSources().get(0)).
            toString().toLowerCase();
    Assert.assertEquals("checking trimmed filter expression:",
            "(((f5 >= 20) and (f2 == 'us')) and (f3 == 15))", actual);
}
 
開發者ID:sigmoidanalytics,項目名稱:spork-streaming,代碼行數:37,代碼來源:TestPartitionFilterPushDown.java

示例6: testColNameMapping4

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
/**
 * Test that pig sends correct partition column names in setPartitionFilter
 * when the user has a schema in the load statement which renames partition
 * columns - in this test case the schema in load statement is a prefix
 * (with columns renamed) of the schema returned by
 * {@link LoadMetadata#getSchema(String, Configuration)}
 * @throws Exception
 */
@Test
public void testColNameMapping4() throws Exception {
    TestLoader.partFilter = null;
    String q = "a = load 'foo' using "
        + TestLoader.class.getName() +
        "('srcid:int, mrkt:chararray, dstid:int, name:chararray, age:int', " +
        "'srcid,mrkt') as (f1:int, f2:chararray, f3:int, name:chararray, age:int);" +
        "b = filter a by " +
        "(age >= 20 and f2 == 'us') and (f1 == 10 and f3 == 15);" + "store b into 'out';";

    LogicalPlan newLogicalPlan = migrateAndOptimizePlan( q );

    Assert.assertEquals("checking partition filter:",
            "((mrkt == 'us') and (srcid == 10))",
            TestLoader.partFilter.toString());
    Operator op = newLogicalPlan.getSinks().get(0);
    LOFilter filter = (LOFilter)newLogicalPlan.getPredecessors(op).get(0);

    PColFilterExtractor extractor = new PColFilterExtractor(filter.getFilterPlan(), new ArrayList<String>());

    String actual = extractor.getExpression(
            (LogicalExpression) filter.getFilterPlan().getSources().get(0)).
            toString().toLowerCase();
    Assert.assertEquals("checking trimmed filter expression:",
            "((age >= 20) and (f3 == 15))", actual);
}
 
開發者ID:sigmoidanalytics,項目名稱:spork-streaming,代碼行數:35,代碼來源:TestPartitionFilterPushDown.java

示例7: test

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
private PColFilterExtractor test(String query, List<String> partitionCols,
        String expPartFilterString, String expFilterString, boolean skipTrimmedFilterCheck)
throws Exception {
    PigServer pigServer = new PigServer( pc );
    LogicalPlan newLogicalPlan = Util.buildLp(pigServer, query);
    Operator op = newLogicalPlan.getSinks().get(0);
    LOFilter filter = (LOFilter)newLogicalPlan.getPredecessors(op).get(0);
    PColFilterExtractor pColExtractor = new PColFilterExtractor(
            filter.getFilterPlan(), partitionCols);
    pColExtractor.visit();

    if(expPartFilterString == null) {
        Assert.assertEquals("Checking partition column filter:", null,
                pColExtractor.getPColCondition());
    } else  {
        Assert.assertEquals("Checking partition column filter:",
                expPartFilterString,
                pColExtractor.getPColCondition().toString());
    }

    // The getExpression() in PColFilterExtractor was written to get the
    // pushdown filter expression and does not have support for columns of
    // type tuple or map as partition columns are expected to be of
    // primitive data type. But we are using the method in the tests for forming
    // trimmed filter after pushdown. So skip check in cases where we expect a
    // trimmed filter to have a map or tuple in the condition.
    if (!skipTrimmedFilterCheck) {
        if (expFilterString == null) {
            Assert.assertTrue("Check that filter can be removed:",
                    pColExtractor.isFilterRemovable());
        } else {
            String actual = pColExtractor
                    .getExpression(
                            (LogicalExpression) filter.getFilterPlan().getSources().get(0))
                    .toString();
            Assert.assertEquals("checking trimmed filter expression:", expFilterString, actual);
        }
    }
    return pColExtractor;
}
 
開發者ID:sigmoidanalytics,項目名稱:spork-streaming,代碼行數:41,代碼來源:TestPartitionFilterPushDown.java

示例8: testColNameMapping1

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
/**
 * Test that pig sends correct partition column names in setPartitionFilter
 * when the user has a schema in the load statement which renames partition
 * columns
 * @throws Exception
 */
@Test
public void testColNameMapping1() throws Exception {
    TestLoader.partFilter = null;
    String q = "a = load 'foo' using "
        + TestLoader.class.getName() + 
        "('srcid:int, mrkt:chararray, dstid:int, name:chararray, age:int', " +
        "'srcid,mrkt') as (f1, f2, f3, f4, f5);" +
        "b = filter a by " +
        "(f5 >= 20 and f2 == 'us') and (f1 == 10 and f3 == 15);" + 
        "store b into 'out';";

    LogicalPlan newLogicalPlan = migrateAndOptimizePlan( q );

    Assert.assertEquals("checking partition filter:",             
            "((mrkt == 'us') and (srcid == 10))",
            TestLoader.partFilter.toString());
    Operator op = newLogicalPlan.getSinks().get(0);
    LOFilter filter = (LOFilter)newLogicalPlan.getPredecessors(op).get(0);
    
    PColFilterExtractor extractor = new PColFilterExtractor(filter.getFilterPlan(), new ArrayList<String>());
    
    String actual = extractor.getExpression(
            (LogicalExpression)filter.getFilterPlan().getSources().get(0)).
            toString().toLowerCase();
    Assert.assertEquals("checking trimmed filter expression:", 
            "((f5 >= 20) and (f3 == 15))", actual);
}
 
開發者ID:PonIC,項目名稱:PonIC,代碼行數:34,代碼來源:TestPartitionFilterPushDown.java

示例9: testColNameMapping2

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
/**
 * Test that pig sends correct partition column names in setPartitionFilter
 * when the user has a schema in the load statement which renames partition
 * columns - in this test case there is no condition on partition columns
 * - so setPartitionFilter() should not be called and the filter condition
 * should remain as is.
 * @throws Exception
 */
@Test
public void testColNameMapping2() throws Exception {
    TestLoader.partFilter = null;
    String q = "a = load 'foo' using "
        + TestLoader.class.getName() + 
        "('srcid:int, mrkt:chararray, dstid:int, name:chararray, age:int', " +
        "'srcid') as (f1, f2, f3, f4, f5);" +
        "b = filter a by " +
        "f5 >= 20 and f2 == 'us' and f3 == 15;" +
        "store b into 'out';";

    LogicalPlan newLogicalPlan = migrateAndOptimizePlan( q );

    Assert.assertEquals("checking partition filter:",             
            null,
            TestLoader.partFilter);
    Operator op = newLogicalPlan.getSinks().get(0);
    LOFilter filter = (LOFilter)newLogicalPlan.getPredecessors(op).get(0);
    
    PColFilterExtractor extractor = new PColFilterExtractor(filter.getFilterPlan(), new ArrayList<String>());
    
    String actual = extractor.getExpression(
            (LogicalExpression) filter.getFilterPlan().
            getSources().get(0)).
            toString().toLowerCase();
    Assert.assertEquals("checking trimmed filter expression:", 
            "(((f5 >= 20) and (f2 == 'us')) and (f3 == 15))", actual);
}
 
開發者ID:PonIC,項目名稱:PonIC,代碼行數:37,代碼來源:TestPartitionFilterPushDown.java

示例10: testColNameMapping4

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
/**
 * Test that pig sends correct partition column names in setPartitionFilter
 * when the user has a schema in the load statement which renames partition
 * columns - in this test case the schema in load statement is a prefix 
 * (with columns renamed) of the schema returned by 
 * {@link LoadMetadata#getSchema(String, Configuration)}
 * @throws Exception
 */
@Test
public void testColNameMapping4() throws Exception {
    TestLoader.partFilter = null;
    String q = "a = load 'foo' using "
        + TestLoader.class.getName() + 
        "('srcid:int, mrkt:chararray, dstid:int, name:chararray, age:int', " +
        "'srcid,mrkt') as (f1:int, f2:chararray, f3:int, name:chararray, age:int);" +
        "b = filter a by " +
        "(age >= 20 and f2 == 'us') and (f1 == 10 and f3 == 15);" + "store b into 'out';";

    LogicalPlan newLogicalPlan = migrateAndOptimizePlan( q );

    Assert.assertEquals("checking partition filter:",             
            "((mrkt == 'us') and (srcid == 10))",
            TestLoader.partFilter.toString());
    Operator op = newLogicalPlan.getSinks().get(0);
    LOFilter filter = (LOFilter)newLogicalPlan.getPredecessors(op).get(0);
    
    PColFilterExtractor extractor = new PColFilterExtractor(filter.getFilterPlan(), new ArrayList<String>());
    
    String actual = extractor.getExpression(
            (LogicalExpression) filter.getFilterPlan().getSources().get(0)).
            toString().toLowerCase();
    Assert.assertEquals("checking trimmed filter expression:", 
            "((age >= 20) and (f3 == 15))", actual);
}
 
開發者ID:PonIC,項目名稱:PonIC,代碼行數:35,代碼來源:TestPartitionFilterPushDown.java

示例11: test

import org.apache.pig.newplan.PColFilterExtractor; //導入依賴的package包/類
private PColFilterExtractor test(String query, List<String> partitionCols, 
        String expPartFilterString, String expFilterString) 
throws Exception {
    PigServer pigServer = new PigServer( pc );
    LogicalPlan newLogicalPlan = Util.buildLp(pigServer, query);
    Operator op = newLogicalPlan.getSinks().get(0);
    LOFilter filter = (LOFilter)newLogicalPlan.getPredecessors(op).get(0);
    PColFilterExtractor pColExtractor = new PColFilterExtractor(
            filter.getFilterPlan(), partitionCols);
    pColExtractor.visit();

    if(expPartFilterString == null) {
        Assert.assertEquals("Checking partition column filter:", null, 
                pColExtractor.getPColCondition());
    } else  {
        Assert.assertEquals("Checking partition column filter:", 
                expPartFilterString.toLowerCase(), 
                pColExtractor.getPColCondition().toString().toLowerCase());   
    }

    if(expFilterString == null) {
        Assert.assertTrue("Check that filter can be removed:", 
                pColExtractor.isFilterRemovable());
    } else {
        String actual = pColExtractor.getExpression(
                (LogicalExpression)filter.getFilterPlan().getSources().get(0)).
                toString().toLowerCase();
        Assert.assertEquals("checking trimmed filter expression:", expFilterString,
                actual);
    }
    return pColExtractor;
}
 
開發者ID:PonIC,項目名稱:PonIC,代碼行數:33,代碼來源:TestPartitionFilterPushDown.java


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