public void openAppender(int suffixId) throws IOException { Path actualFilePath = lastFileName; if (suffixId > 0) { actualFilePath = new Path(lastFileName + "_" + suffixId); } appender = ((FileTablespace) TablespaceManager.get(lastFileName.toUri())) .getAppender(meta, outSchema, actualFilePath); appender.enableStats(); appender.init(); }
public void openAppender(int suffixId) throws IOException { Path actualFilePath = lastFileName; if (suffixId > 0) { actualFilePath = new Path(lastFileName + "_" + suffixId); } appender = ((FileTablespace) TablespaceManager.get(lastFileName.toUri())) .getAppender(meta, outSchema, actualFilePath); appender.enableStats(); appender.init(); }
public void openNewFile(int suffixId) throws IOException { Schema appenderSchema = (plan instanceof InsertNode) ? ((InsertNode) plan).getTableSchema() : outSchema; if (PlannerUtil.isFileStorageType(meta.getDataFormat())) { String prevFile = null; lastFileName = context.getOutputPath(); if (suffixId > 0) { prevFile = lastFileName.toString(); lastFileName = new Path(lastFileName + "_" + suffixId); } FileTablespace space = TablespaceManager.get(lastFileName.toUri()); appender = space.getAppender(meta, appenderSchema, lastFileName); if (suffixId > 0) { LOG.info(prevFile + " exceeds " + SessionVars.MAX_OUTPUT_FILE_SIZE.keyname() + " (" + maxPerFileSize + " MB), " + "The remain output will be written into " + lastFileName.toString()); } } else { Path stagingDir = context.getQueryContext().getStagingDir(); appender = TablespaceManager.get(stagingDir.toUri()).getAppender( context.getQueryContext(), context.getTaskId(), meta, appenderSchema, stagingDir); } appender.enableStats(); appender.init(); }
public void openNewFile(int suffixId) throws IOException { Schema appenderSchema = (plan instanceof InsertNode) ? ((InsertNode) plan).getTableSchema() : outSchema; if (PlannerUtil.isFileStorageType(meta.getDataFormat())) { String prevFile = null; lastFileName = context.getOutputPath(); if (suffixId > 0) { prevFile = lastFileName.toString(); lastFileName = new Path(lastFileName + "_" + suffixId); } FileTablespace space = TablespaceManager.get(lastFileName.toUri()); appender = space.getAppender(meta, appenderSchema, lastFileName); if (suffixId > 0) { LOG.info(prevFile + " exceeds " + SessionVars.MAX_OUTPUT_FILE_SIZE.keyname() + " (" + maxPerFileSize + " MB), " + "The remain output will be written into " + lastFileName.toString()); } } else { Path stagingDir = context.getQueryContext().getStagingDir(); appender = TablespaceManager.get(stagingDir.toUri()).getAppender( context.getQueryContext(), context.getTaskId(), meta, appenderSchema, stagingDir); } appender.enableStats(); appender.init(); }
public static void writeTmpTable(TajoConf conf, Path tablePath) throws IOException { FileTablespace sm = TablespaceManager.getDefault(); Appender appender; Path filePath = new Path(tablePath, "table.csv"); FileSystem fs = filePath.getFileSystem(conf); if (fs.exists(tablePath)) { fs.delete(tablePath, true); } fs.mkdirs(tablePath); appender = sm.getAppender(mockupMeta, mockupSchema, filePath); appender.init(); int deptSize = 10000; int tupleNum = 100; Tuple tuple; for (int i = 0; i < tupleNum; i++) { tuple = new VTuple(2); String key = "test" + (i % deptSize); tuple.put(0, DatumFactory.createText(key)); tuple.put(1, DatumFactory.createInt4(i + 1)); appender.addTuple(tuple); } appender.close(); } }
@Test public void testFileAlreadyExists() throws IOException { if (internalType) return; Schema schema = SchemaBuilder.builder() .add("id", Type.INT4) .add("age", Type.INT8) .add("score", Type.FLOAT4) .build(); TableMeta meta = CatalogUtil.newTableMeta(dataFormat, conf); if (dataFormat.equalsIgnoreCase(BuiltinStorages.AVRO)) { meta.putProperty(StorageConstants.AVRO_SCHEMA_LITERAL, TEST_PROJECTION_AVRO_SCHEMA); } FileTablespace sm = TablespaceManager.getLocalFs(); Path tablePath = new Path(testDir, "testFileAlreadyExists.data"); Appender appender = sm.getAppender(meta, schema, tablePath); appender.init(); appender.close(); try { appender = sm.getAppender(meta, schema, tablePath); appender.init(); if (BuiltinStorages.ORC.equals(dataFormat)) { appender.close(); } fail(dataFormat); } catch (IOException e) { } finally { IOUtils.cleanup(null, appender); } }
appender.init(); for (Tuple t : tuples) { appender.addTuple(t);
appender = (((FileTablespace) TablespaceManager.getLocalFs())) .getAppender(tableMeta, schema, dataPath); appender.init();
public void init() throws IOException { super.init(); if (plan.hasOptions()) { meta = CatalogUtil.newTableMeta(plan.getStorageType(), plan.getOptions()); } else { meta = CatalogUtil.newTableMeta(plan.getStorageType(), context.getConf()); } PhysicalPlanUtil.setNullCharIfNecessary(context.getQueryContext(), plan, meta); sumStats = new TableStats(); StoreTableNode storeTableNode = (StoreTableNode) plan; appender = TablespaceManager.get(storeTableNode.getUri()).getAppenderForInsertRow( context.getQueryContext(), context.getTaskId(), meta, storeTableNode.getTableSchema(), context.getOutputPath()); appender.enableStats(); appender.init(); }
public void init() throws IOException { super.init(); if (plan.hasOptions()) { meta = CatalogUtil.newTableMeta(plan.getStorageType(), plan.getOptions()); } else { meta = CatalogUtil.newTableMeta(plan.getStorageType(), context.getConf()); } PhysicalPlanUtil.setNullCharIfNecessary(context.getQueryContext(), plan, meta); sumStats = new TableStats(); StoreTableNode storeTableNode = (StoreTableNode) plan; appender = TablespaceManager.get(storeTableNode.getUri()).getAppenderForInsertRow( context.getQueryContext(), context.getTaskId(), meta, storeTableNode.getTableSchema(), context.getOutputPath()); appender.enableStats(); appender.init(); }
Appender appender = sm.getAppender(meta, schema, tablePath); appender.enableStats(); appender.init(); appender.close();
FileTablespace sm = TablespaceManager.getLocalFs(); Appender appender = sm.getAppender(meta, dataSchema, tablePath); appender.init();
appender.init(); for(Tuple t : tuples) { appender.addTuple(t);
Path tablePath = new Path(testDir, "testVariableLength.data"); Appender appender = sm.getAppender(meta, schema, tablePath); appender.init();
Path tablePath = new Path(testDir, "testSerializer.data"); Appender appender = sm.getAppender(meta, schema, tablePath); appender.init();
@Test public void testDateTextHandling() throws Exception { if (dataFormat.equalsIgnoreCase(BuiltinStorages.AVRO) || internalType) { return; } Schema schema = SchemaBuilder.builder().add("col1", Type.TEXT).build(); TableMeta meta = CatalogUtil.newTableMeta(dataFormat, conf); FileTablespace sm = TablespaceManager.getLocalFs(); Path tablePath = new Path(testDir, "testTextHandling.data"); Appender appender = sm.getAppender(meta, schema, tablePath); appender.init(); VTuple tuple = new VTuple(1); tuple.put(0, DatumFactory.createDate(1994,7,30)); appender.addTuple(tuple); appender.flush(); appender.close(); FileStatus status = fs.getFileStatus(tablePath); FileFragment fragment = new FileFragment("table", tablePath, 0, status.getLen()); Scanner scanner = sm.getScanner(meta, schema, fragment, null); scanner.init(); Tuple retrieved; while ((retrieved = scanner.next()) != null) { assertEquals(tuple.get(0).asChars(), retrieved.asDatum(0).asChars()); } scanner.close(); if (internalType){ OldStorageManager.clearCache(); } }
FileTablespace sm = TablespaceManager.getLocalFs(); Appender appender = sm.getAppender(meta, schema, tablePath); appender.init();
.getAppender(scoreLargeMeta, scoreSchmea, scoreLargePath); appender.enableStats(); appender.init(); largeScore = new TableDesc( IdentifierUtil.buildFQName(TajoConstants.DEFAULT_DATABASE_NAME, "score_large"), scoreSchmea, scoreLargeMeta,
appender.init(); VTuple tuple = new VTuple(schema.size()); for (int i = 0; i < 100; i++) {
Path tablePath = new Path(testDir, "testProgress.data"); Appender appender = sm.getAppender(meta, schema, tablePath); appender.init();