org.apache.kudu.client.RowResultIterator Java Examples
The following examples show how to use
org.apache.kudu.client.RowResultIterator.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: SchemaEmulationByTableNameConvention.java From presto with Apache License 2.0 | 6 votes |
@Override public List<String> listSchemaNames(KuduClient client) { try { if (rawSchemasTable == null) { if (!client.tableExists(rawSchemasTableName)) { createAndFillSchemasTable(client); } rawSchemasTable = getSchemasTable(client); } KuduScanner scanner = client.newScannerBuilder(rawSchemasTable).build(); RowResultIterator iterator = scanner.nextRows(); ArrayList<String> result = new ArrayList<>(); while (iterator != null) { for (RowResult row : iterator) { result.add(row.getString(0)); } iterator = scanner.nextRows(); } return result; } catch (KuduException e) { throw new PrestoException(GENERIC_INTERNAL_ERROR, e); } }
Example #2
Source File: KuduConsumerTest.java From syndesis with Apache License 2.0 | 6 votes |
@Ignore public void insertRow() throws KuduException, InterruptedException { MockEndpoint mock = getMockEndpoint("mock:result"); mock.expectedMessageCount(1); assertMockEndpointsSatisfied(); List<Exchange> exchanges = mock.getReceivedExchanges(); assertEquals(1, exchanges.size()); KuduScanner scanner = exchanges.get(0).getIn().getBody(KuduScanner.class); RowResultIterator results = scanner.nextRows(); RowResult result = results.next(); ColumnSchema columnByIndex = result.getSchema().getColumnByIndex(0); String name = columnByIndex.getName(); assertEquals("id", name); assertEquals(46, result.getInt(0)); assertEquals(10, result.getInt(1)); }
Example #3
Source File: KuduInputOperatorCommons.java From attic-apex-malhar with Apache License 2.0 | 6 votes |
public long countNumRowsInTable() throws Exception { List<String> allProjectedCols = new ArrayList<>( unitTestStepwiseScanInputOperator.getKuduColNameToSchemaMapping().keySet()); KuduScanner scanner = kuduClient.newScannerBuilder(kuduTable) .setProjectedColumnNames(allProjectedCols) .build(); long counter = 0; while (scanner.hasMoreRows()) { RowResultIterator rowResultItr = scanner.nextRows(); while (rowResultItr.hasNext()) { RowResult thisRow = rowResultItr.next(); counter += 1; } } return counter; }
Example #4
Source File: KuduClientTestCommons.java From attic-apex-malhar with Apache License 2.0 | 6 votes |
protected void lookUpAndPopulateRecord(UnitTestTablePojo keyInfo) throws Exception { KuduScanner scanner = kuduClient.newScannerBuilder(kuduTable) .addPredicate(KuduPredicate.newComparisonPredicate(columnDefs.get("introwkey"), KuduPredicate.ComparisonOp.EQUAL,keyInfo.getIntrowkey())) .addPredicate(KuduPredicate.newComparisonPredicate(columnDefs.get("stringrowkey"), KuduPredicate.ComparisonOp.EQUAL,keyInfo.getStringrowkey())) .addPredicate(KuduPredicate.newComparisonPredicate(columnDefs.get("timestamprowkey"), KuduPredicate.ComparisonOp.EQUAL,keyInfo.getTimestamprowkey())) .build(); RowResultIterator rowResultItr = scanner.nextRows(); while (rowResultItr.hasNext()) { RowResult thisRow = rowResultItr.next(); keyInfo.setFloatdata(thisRow.getFloat("floatdata")); keyInfo.setBooldata(thisRow.getBoolean("booldata")); keyInfo.setBinarydata(thisRow.getBinary("binarydata")); keyInfo.setLongdata(thisRow.getLong("longdata")); keyInfo.setTimestampdata(thisRow.getLong("timestampdata")); keyInfo.setStringdata("stringdata"); break; } }
Example #5
Source File: KuduOperations.java From geowave with Apache License 2.0 | 6 votes |
public List<Delete> getDeletions( final KuduTable table, final List<KuduPredicate> predicates, final Function<RowResult, PersistentKuduRow> adapter) throws KuduException { // TODO: Kudu Java API does not support deleting with predicates, so we first perform a scan and // then perform individual row deletions with the full primary key. This is inefficient, because // we need to read in entire rows in order to perform deletions. final KuduScannerBuilder scannerBuilder = getScannerBuilder(table); for (final KuduPredicate pred : predicates) { scannerBuilder.addPredicate(pred); } final KuduScanner scanner = scannerBuilder.build(); final List<RowResultIterator> allResults = new ArrayList<>(); while (scanner.hasMoreRows()) { allResults.add(scanner.nextRows()); } final Iterator<Delete> deletions = Streams.stream(Iterators.concat(allResults.iterator())).map(result -> { final PersistentKuduRow row = adapter.apply(result); final Delete delete = table.newDelete(); row.populatePartialRowPrimaryKey(delete.getRow()); return delete; }).iterator(); return Lists.newArrayList(deletions); }
Example #6
Source File: NativeKuduClientSession.java From presto-kudu with Apache License 2.0 | 5 votes |
@Override public List<String> listSchemaNames() { try { if (rawSchemasTable == null) { if (!client.tableExists(rawSchemasTableName)) { createAndFillSchemasTable(); } rawSchemasTable = getSchemasTable(); } ColumnSchema tenantColumn = rawSchemasTable.getSchema().getColumnByIndex(0); KuduScanner scanner = client.newScannerBuilder(rawSchemasTable) .addPredicate(KuduPredicate.newComparisonPredicate(tenantColumn, KuduPredicate.ComparisonOp.EQUAL, tenantPrefix)) .setProjectedColumnIndexes(ImmutableList.of(1)) .build(); RowResultIterator iterator = scanner.nextRows(); ArrayList<String> result = new ArrayList<>(); while (iterator != null) { for (RowResult row : iterator) { result.add(row.getString(0)); } iterator = scanner.nextRows(); } return result; } catch (KuduException e) { throw new PrestoException(GENERIC_INTERNAL_ERROR, e); } }
Example #7
Source File: Tags.java From kudu-ts with Apache License 2.0 | 5 votes |
/** * Retrieves the tagset IDs of all tagsets which contain the specified tag. * The tagset IDs are returned in sorted order. * * @param key the tag key * @param value the tag value * @return the sorted tagset IDs */ public Deferred<IntVec> getTagsetIDsForTag(final String key, final String value) { AsyncKuduScanner.AsyncKuduScannerBuilder scan = client.newScannerBuilder(table); scan.addPredicate(KuduPredicate.newComparisonPredicate(Tables.TAGS_KEY_COLUMN, ComparisonOp.EQUAL, key)); scan.addPredicate(KuduPredicate.newComparisonPredicate(Tables.TAGS_VALUE_COLUMN, ComparisonOp.EQUAL, value)); scan.setProjectedColumnIndexes(TAGSET_ID_PROJECTION); final AsyncKuduScanner scanner = scan.build(); class GetTagCB implements Callback<Deferred<IntVec>, RowResultIterator> { private final IntVec tagsetIDs = IntVec.create(); @Override public Deferred<IntVec> call(RowResultIterator results) { for (RowResult result : results) { tagsetIDs.push(result.getInt(0)); } if (scanner.hasMoreRows()) { return scanner.nextRows().addCallbackDeferring(this); } // The Kudu java client doesn't yet allow us to specify a sorted // (fault-tolerant) scan, so have to sort manually. tagsetIDs.sort(); return Deferred.fromResult(tagsetIDs); } @Override public String toString() { return MoreObjects.toStringHelper(this).add("key", key).add("value", value).toString(); } } return scanner.nextRows().addCallbackDeferring(new GetTagCB()); }
Example #8
Source File: Tagsets.java From kudu-ts with Apache License 2.0 | 5 votes |
@Override public Deferred<TagsetLookupResult> call(RowResultIterator rows) { for (RowResult row : rows) { int id = row.getInt(Tables.TAGSETS_ID_INDEX); Preconditions.checkState(id >= probe); if (id != probe) { // We found a hole in the table where we expected the tagset. return Deferred.fromResult(new TagsetLookupResult(false, probe)); } if (tagset.equals(row.getBinary(Tables.TAGSETS_TAGSET_INDEX))) { return Deferred.fromResult(new TagsetLookupResult(true, id)); } probe++; } // We probed through the entire RowResult and didn't find the tagset. if (!scanner.hasMoreRows()) { if (probe <= Ints.saturatedCast((long) id + TAGSETS_PER_SCAN)) { // We found a hole at the end of the scan. return Deferred.fromResult(new TagsetLookupResult(false, probe)); } // The current scanner has been exhausted; create a new scanner from the // latest probe point. scanner = tagsetScanner(probe); id = probe; } return scanner.nextRows().addCallbackDeferring(this); }
Example #9
Source File: KuduInputOperatorCommons.java From attic-apex-malhar with Apache License 2.0 | 5 votes |
public void truncateTable() throws Exception { AbstractKuduPartitionScanner<UnitTestTablePojo,InputOperatorControlTuple> scannerForDeletingRows = unitTestStepwiseScanInputOperator.getScanner(); List<KuduScanToken> scansForAllTablets = unitTestStepwiseScanInputOperator .getPartitioner().getKuduScanTokensForSelectAllColumns(); ApexKuduConnection aCurrentConnection = scannerForDeletingRows.getConnectionPoolForThreads().get(0); KuduSession aSessionForDeletes = aCurrentConnection.getKuduClient().newSession(); KuduTable currentTable = aCurrentConnection.getKuduTable(); for ( KuduScanToken aTabletScanToken : scansForAllTablets) { KuduScanner aScanner = aTabletScanToken.intoScanner(aCurrentConnection.getKuduClient()); while ( aScanner.hasMoreRows()) { RowResultIterator itrForRows = aScanner.nextRows(); while ( itrForRows.hasNext()) { RowResult aRow = itrForRows.next(); int intRowKey = aRow.getInt("introwkey"); String stringRowKey = aRow.getString("stringrowkey"); long timestampRowKey = aRow.getLong("timestamprowkey"); Delete aDeleteOp = currentTable.newDelete(); aDeleteOp.getRow().addInt("introwkey",intRowKey); aDeleteOp.getRow().addString("stringrowkey", stringRowKey); aDeleteOp.getRow().addLong("timestamprowkey",timestampRowKey); aSessionForDeletes.apply(aDeleteOp); } } } aSessionForDeletes.close(); Thread.sleep(2000); // Sleep to allow for scans to complete }
Example #10
Source File: KuduScanCustomizer.java From syndesis with Apache License 2.0 | 4 votes |
private static void processBody(Exchange exchange) throws KuduException, JsonProcessingException { final Message in = exchange.getIn(); final KuduScanner scanner = in.getBody(KuduScanner.class); final List<String> answer = new ArrayList<>(); while(scanner.hasMoreRows()) { RowResultIterator results = scanner.nextRows(); while (results.hasNext()) { Map<String, Object> row = new HashMap<String, Object>(); RowResult result = results.next(); for (int i = 0; i < result.getSchema().getColumnCount(); i++) { String key = result.getSchema().getColumnByIndex(i).getName(); Type type = result.getColumnType(i); switch (type.getName()) { case "string": row.put(key, result.getString(i)); break; case "bool": row.put(key, result.getBoolean(i)); break; case "int8": case "int16": case "int32": row.put(key, result.getInt(i)); break; case "int64": row.put(key, result.getLong(i)); break; case "double": row.put(key, result.getDouble(i)); break; case "float": row.put(key, result.getFloat(i)); break; default: throw new SyndesisServerException("The column schema type " + type.getName() + " for column " + key + " is not supported at the moment"); } } answer.add(KuduSupport.toJSONBean(row)); } } in.setBody(answer); }
Example #11
Source File: KuduPartitionScannerCallable.java From attic-apex-malhar with Apache License 2.0 | 4 votes |
@Override public Long call() throws Exception { long numRowsScanned = 0; KuduScanner aPartitionSpecificScanner = KuduScanToken.deserializeIntoScanner( kuduPartitionScanAssignmentMeta.getSerializedKuduScanToken(), kuduClientHandle); LOG.info("Scanning the following tablet " + KuduScanToken.stringifySerializedToken(kuduPartitionScanAssignmentMeta .getSerializedKuduScanToken(), kuduClientHandle)); KuduRecordWithMeta<T> beginScanRecord = new KuduRecordWithMeta<>(); beginScanRecord.setBeginScanMarker(true); beginScanRecord.setTabletMetadata(kuduPartitionScanAssignmentMeta); bufferForTransmittingRecords.add(beginScanRecord); // Add a record entry that denotes the end of this scan. while ( aPartitionSpecificScanner.hasMoreRows()) { LOG.debug("Number of columns being returned for this read " + aPartitionSpecificScanner.getProjectionSchema().getColumnCount()); RowResultIterator resultIterator = aPartitionSpecificScanner.nextRows(); if (resultIterator == null) { break; } else { while (resultIterator.hasNext()) { KuduRecordWithMeta<T> recordWithMeta = new KuduRecordWithMeta<>(); RowResult aRow = resultIterator.next(); recordWithMeta.setPositionInScan(numRowsScanned); T payload = clazzForResultObject.newInstance(); recordWithMeta.setThePayload(payload); recordWithMeta.setEndOfScanMarker(false); recordWithMeta.setTabletMetadata(kuduPartitionScanAssignmentMeta); setValuesInPOJO(aRow,payload); bufferForTransmittingRecords.add(recordWithMeta); numRowsScanned += 1; } } } aPartitionSpecificScanner.close(); KuduRecordWithMeta<T> endScanRecord = new KuduRecordWithMeta<>(); endScanRecord.setEndOfScanMarker(true); endScanRecord.setTabletMetadata(kuduPartitionScanAssignmentMeta); bufferForTransmittingRecords.add(endScanRecord); // Add a record entry that denotes the end of this scan. LOG.info(" Scanned a total of " + numRowsScanned + " for this scanner thread @tablet " + KuduScanToken.stringifySerializedToken(kuduPartitionScanAssignmentMeta.getSerializedKuduScanToken(), kuduClientHandle)); return numRowsScanned; }