当前位置: 首页>>代码示例>>Java>>正文


Java CopyManager类代码示例

本文整理汇总了Java中org.postgresql.copy.CopyManager的典型用法代码示例。如果您正苦于以下问题:Java CopyManager类的具体用法?Java CopyManager怎么用?Java CopyManager使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


CopyManager类属于org.postgresql.copy包,在下文中一共展示了CopyManager类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: saveAll

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
public void saveAll(PGConnection connection, Stream<TEntity> entities) throws SQLException {

        CopyManager cpManager = connection.getCopyAPI();
        CopyIn copyIn = cpManager.copyIn(getCopyCommand());

        try (PgBinaryWriter bw = new PgBinaryWriter()) {

            // Wrap the CopyOutputStream in our own Writer:
            bw.open(new PGCopyOutputStream(copyIn));

            // Insert Each Column:
            entities.forEach(entity -> this.saveEntity(bw, entity));
        }
    }
 
开发者ID:bytefish,项目名称:PgBulkInsert,代码行数:15,代码来源:PgBulkInsert.java

示例2: call

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
@Override
public Long call() throws SQLException, IOException {
  try {
    CopyManager mgr = new CopyManager((BaseConnection) conn);
    return mgr.copyIn(sql, pipeIn);
  } finally {
    try {
      pipeIn.close();
    } catch (IOException ignore) {
    }
  }
}
 
开发者ID:HashDataInc,项目名称:bireme,代码行数:13,代码来源:ChangeLoader.java

示例3: execute

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
@Override
public void execute(Connection connection,
                    TypeConverterStore converterStore,
                    SqlCache sqlCache,
                    DataSourceAdapter dataSourceAdapter) throws Exception {
    String theSql = sql == null ? sqlCache.get(filename) : sql;
    PGConnection pgConn = dataSourceAdapter.unwrapPgConnection(connection);
    CopyManager copyManager = (pgConn).getCopyAPI();
    fileReader = new FileReader(copyFile);
    copyManager.copyIn(theSql, fileReader);
}
 
开发者ID:manniwood,项目名称:cl4pg,代码行数:12,代码来源:CopyFileIn.java

示例4: load

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
/**
 *
 * @param con open postgres! connection
 * @param folder the classpath folder to scan for table data files
 * @param truncate if true first truncates the tables
 * @throws Exception
 */
public static void load(Connection con, String folder, boolean truncate) throws Exception {
    con.setAutoCommit(false);
    LOG.info("Load data from " + folder);
    CopyManager copy = ((PGConnection)con).getCopyAPI();
    List<String> tables = listTables(folder);
    if (truncate) {
        truncate(con, tables);
    }
    con.commit();

    for (String table : tables) {
        LOG.debug("Load table " + table);
        InputStreamWithoutHeader in = new InputStreamWithoutHeader(FileUtils.classpathStream(folder + "/" + table + FILE_SUFFIX), '\t', '\n');
        String header = HEADER_JOINER.join(in.header);
        copy.copyIn("COPY " + table + "(" + header + ") FROM STDOUT WITH NULL '\\N'", in);
    }
    con.commit();
}
 
开发者ID:gbif,项目名称:checklistbank,代码行数:26,代码来源:DbLoader.java

示例5: metadataToPostgres

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
private void metadataToPostgres() {
	try {
		CopyManager cpManager = new CopyManager((BaseConnection) conn);
		st.executeUpdate("TRUNCATE TABLE metadata;");
		String metaFile = this.dataDirectory + File.separator + this.metadataFile;
		this.logger.log(Level.INFO, "Importing metadata from " + metaFile);
		Long n = cpManager.copyIn("COPY metadata FROM STDIN WITH CSV", new FileReader(metaFile));
		this.logger.log(Level.INFO, n + " metadata imported");
	} catch (Exception e) {
		e.printStackTrace();
		System.exit(1);
	}
}
 
开发者ID:tudarmstadt-lt,项目名称:newsleak-frontend,代码行数:14,代码来源:InformationExtraction2Postgres.java

示例6: testCopy

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
public static void testCopy() throws ClassNotFoundException, SQLException, IOException {
	Long start = System.nanoTime();
	Class.forName("org.postgresql.Driver");
	Connection conn = DriverManager.getConnection("jdbc:postgresql://192.168.100.8:5866/sqoop", "hive", "highgo");
	CopyManager cm = new CopyManager((BaseConnection) conn);
	Reader reader = new FileReader(new File("result"));
	cm.copyIn("copy testnumberictypes from STDIN", reader);
	Long end = System.nanoTime();
	System.out.println((end - start) / Math.pow(10, 9));
}
 
开发者ID:chenzhenyang,项目名称:aquila,代码行数:11,代码来源:TestPgCopyManager.java

示例7: execute

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
@Override
public void execute(Connection connection,
                    TypeConverterStore converterStore,
                    SqlCache sqlCache,
                    DataSourceAdapter dataSourceAdapter) throws Exception {
    String theSql = sql == null ? sqlCache.get(filename) : sql;
    PGConnection pgConn = dataSourceAdapter.unwrapPgConnection(connection);
    CopyManager copyManager = (pgConn).getCopyAPI();
    fileWriter = new FileWriter(copyFile);
    copyManager.copyOut(theSql, fileWriter);
}
 
开发者ID:manniwood,项目名称:cl4pg,代码行数:12,代码来源:CopyFileOut.java

示例8: load

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
/**
 * Loads known usages from checklistbank backbone.
 */
public IdLookupImpl load(ClbConfiguration clb, boolean includeDeleted) throws SQLException, IOException {
  try (Connection c = clb.connect()) {
    final CopyManager cm = new CopyManager((BaseConnection) c);
    final String delClause = includeDeleted ? "" : " AND deleted is null";

    // first read bulk of regular usages - we add pro parte usage later
    LOG.info("Reading existing nub usages {}from postgres ...", includeDeleted ? "incl. deleted " : "");
    try (Writer writer = new UsageWriter()) {
      cm.copyOut("COPY ("
          + "SELECT u.id, coalesce(NULLIF(trim(n.canonical_name), ''), n.scientific_name), n.authorship, n.year, u.rank, u.kingdom_fk, deleted is not null"
          + " FROM name_usage u join name n ON name_fk=n.id"
          + " WHERE dataset_key = '" + Constants.NUB_DATASET_KEY + "'" + delClause + " AND pp_synonym_fk is null)"
          + " TO STDOUT WITH NULL ''", writer);
      LOG.info("Added {} nub usages into id lookup", usages.size());
    }
    final int uCount = usages.size();

    // now load pro parte keys separately saving us from doing complex aggregations
    LOG.info("Reading existing pro parte nub usages {}from postgres ...", includeDeleted ? "incl. deleted " : "");
    try (Writer writer = new ProParteUsageWriter()) {
      cm.copyOut("COPY ("
          + "SELECT u.id, u.parent_fk, u.pp_synonym_fk, coalesce(NULLIF(trim(n.canonical_name), ''), n.scientific_name), n.authorship, n.year, u.rank, u.kingdom_fk, deleted is not null"
          + " FROM name_usage u join name n ON name_fk=n.id"
          + " WHERE dataset_key = '" + Constants.NUB_DATASET_KEY + "'" + delClause + " AND pp_synonym_fk is not null"
          + " ORDER BY pp_synonym_fk)"
          + " TO STDOUT WITH NULL ''", writer);
      LOG.info("Added {} pro parte usages into id lookup", usages.size() - uCount);
    }
    LOG.info("Loaded existing nub with {} usages and max key {} into id lookup", usages.size(), keyMax);
  }
  return this;
}
 
开发者ID:gbif,项目名称:checklistbank,代码行数:36,代码来源:IdLookupImpl.java

示例9: initNeo

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
@Override
public void initNeo(NeoUsageWriter writer) throws Exception {
  try (BaseConnection c = (BaseConnection) clb.connect()) {
    final CopyManager cm = new CopyManager(c);
    cm.copyOut("COPY ("
        + "SELECT u.id, u.parent_fk, u.basionym_fk, u.rank,"
        + " coalesce(u.status, CASE WHEN (u.is_synonym) THEN 'SYNONYM'::taxonomic_status ELSE 'ACCEPTED'::taxonomic_status END),"
        + " u.nom_status, n.scientific_name, c.citation"
        + " FROM name_usage u JOIN name n ON u.name_fk=n.id LEFT JOIN citation c ON u.name_published_in_fk=c.id"
        + " WHERE u.dataset_key = '" + key + "')"
        + " TO STDOUT WITH NULL ''", writer);
  }
}
 
开发者ID:gbif,项目名称:checklistbank,代码行数:14,代码来源:ClbSource.java

示例10: exportData

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
/**
 * Executes a COPY operation and reads the output stream to a file
 * @param dbName
 * @param sql
 * @param file
 * @return
 * @throws IOException
 * @throws ClassNotFoundException
 * @throws SQLException
 * @throws Exception
 */
private File exportData(String server, String dbName, String sql, File file) throws IOException, ClassNotFoundException, SQLException, Exception{
	//
	// Get DBUtils instance for the specified database
	//
	//ORDSPostgresDBUtils dbUtils = new ORDSPostgresDBUtils(server, dbName, user, password);

	//
	// Get QueryRunner instance for the specified database
	//
	QueryRunner qr = new QueryRunner(server, dbName);

	//
	// Create a writer for outputting the CSV to the file, and get
	// the Postgres DB connection we'll use for reading the input from
	//
	BufferedWriter writer = new BufferedWriter(new OutputStreamWriter( new FileOutputStream(file), "UTF8"));
	Connection conn = qr.getConnection();

	try {
		//
		// Obtain CopyManager from the Postgres Connection
		//
		PGConnection pg_conn = (PGConnection)conn;
		CopyManager copyManager = pg_conn.getCopyAPI();

		//
		// Copy out the data to the writer
		//
		copyManager.copyOut(sql, writer);
	} catch (Exception e) {
		file.deleteOnExit();
		throw new Exception("Error exporting table", e);
	} finally {
		//
		// Close writer
		//
		writer.close();

		//
		// Close DB connection
		//
		conn.close();
	}
	return file;
}
 
开发者ID:ox-it,项目名称:ords-database-api,代码行数:57,代码来源:PostgresCsvServiceImpl.java

示例11: appendDataFromFile

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
@Override
public void appendDataFromFile(String server, String dbName, String tableName, File file, boolean headerRow, boolean useColumnNames) throws Exception{

	//
	// Get DBUtils instance for the specified database
	//
	//ORDSPostgresDBUtils dbUtils = new ORDSPostgresDBUtils(server, dbName, user, password);

	//
	// Get QueryRunner instance for the specified database
	//
	QueryRunner qr = new QueryRunner(server, dbName);


	//
	// Define the copy operation
	//

	String sql = "COPY "+tableName;
	if (useColumnNames) {
		String names[];
		
		if (headerRow) {
			names = getColumnNames(server, dbName, tableName, file, true);
		}
		else {
			names = this.getColumnNamesFromDatabase(server, dbName, tableName);
		}
		sql += " ("+GeneralUtils.implode(",", names) + ")";
	}
	sql +=  " FROM STDIN WITH CSV ENCODING 'UTF8'";
	if ( headerRow ) {
		sql +=  " HEADER";
	}
	
	//
	// Create a reader for getting the data from the file and get
	// the Postgres DB connection we'll use for writing the output
	//
	BufferedReader reader = new BufferedReader( new InputStreamReader( new FileInputStream(file), "UTF8"));

	Connection conn = qr.getConnection();

	try {
		//
		// Obtain CopyManager from the Postgres Connection
		//
		PGConnection pg_conn = (PGConnection)conn;
		CopyManager copyManager = pg_conn.getCopyAPI();	
		//
		// Copy in the data
		//
		copyManager.copyIn(sql, reader);
		
	}finally {
		//
		// Close writer
		//
		reader.close();

		//
		// Close DB connection
		//
		conn.close();
	}
}
 
开发者ID:ox-it,项目名称:ords-database-api,代码行数:67,代码来源:PostgresCsvServiceImpl.java

示例12: importFile

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
/**
 * This is a blocking call - run in an execBlocking statement
 * import data in a tab delimited file into columns of an existing table
 * Using only default values of the COPY FROM STDIN Postgres command
 * @param path - path to the file
 * @param tableName - name of the table to import the content into
 */
public void importFile(String path, String tableName) {

 long recordsImported[] = new long[]{-1};
 vertx.<String>executeBlocking(dothis -> {

  try {
    String host = postgreSQLClientConfig.getString(HOST);
    int port = postgreSQLClientConfig.getInteger(PORT);
    String user = postgreSQLClientConfig.getString(_USERNAME);
    String pass = postgreSQLClientConfig.getString(_PASSWORD);
    String db = postgreSQLClientConfig.getString(DATABASE);

    log.info("Connecting to " + db);

    Connection con = DriverManager.getConnection(
      "jdbc:postgresql://"+host+":"+port+"/"+db, user , pass);

    log.info("Copying text data rows from stdin");

    CopyManager copyManager = new CopyManager((BaseConnection) con);

    FileReader fileReader = new FileReader(path);
    recordsImported[0] = copyManager.copyIn("COPY "+tableName+" FROM STDIN", fileReader );

  } catch (Exception e) {
    log.error(messages.getMessage("en", MessageConsts.ImportFailed), e);
    dothis.fail(e);
  }
  dothis.complete("Done.");

}, whendone -> {

  if(whendone.succeeded()){

    log.info("Done importing file: " + path + ". Number of records imported: " + recordsImported[0]);
  }
  else{
    log.info("Failed importing file: " + path);
  }

});

}
 
开发者ID:folio-org,项目名称:raml-module-builder,代码行数:51,代码来源:PostgresClient.java

示例13: testCopy100RecordsIntoFile

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
@Test
@Ignore("not used right now in read code")
public void testCopy100RecordsIntoFile() throws Exception {
    System.out.println("Starting");

    int a = 0;

    long start = System.currentTimeMillis();
    try (Connection connection = dbManager.getConnection();
         PreparedStatement ps = connection.prepareStatement(ReportingDBDao.insertMinute)) {

        String userName = "[email protected]";
        long minute = (System.currentTimeMillis() / AverageAggregatorProcessor.MINUTE) * AverageAggregatorProcessor.MINUTE;

        for (int i = 0; i < 100; i++) {
            ReportingDBDao.prepareReportingInsert(ps, userName, 1, 0, (byte) 0, 'v', minute, (double) i);
            ps.addBatch();
            minute += AverageAggregatorProcessor.MINUTE;
            a++;
        }

        ps.executeBatch();
        connection.commit();
    }

    System.out.println("Finished : " + (System.currentTimeMillis() - start)  + " millis. Executed : " + a);


    try (Connection connection = dbManager.getConnection();
         Writer gzipWriter = new OutputStreamWriter(new GZIPOutputStream(new FileOutputStream(new File("/home/doom369/output.csv.gz"))), "UTF-8")) {

        CopyManager copyManager = new CopyManager(connection.unwrap(BaseConnection.class));


        String selectQuery = "select pintype || pin, ts, value from reporting_average_minute where project_id = 1 and email = '[email protected]'";
        long res = copyManager.copyOut("COPY (" + selectQuery + " ) TO STDOUT WITH (FORMAT CSV)", gzipWriter);
        System.out.println(res);
    }


}
 
开发者ID:blynkkk,项目名称:blynk-server,代码行数:42,代码来源:DBManagerTest.java

示例14: dumpTableInformation

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
/**
 * Uses the given {@link Connection connection} to COPY the table information from the table given
 * as table name to the directory given as testDataDirectory.
 *
 * @param connection The connection over which to execute the COPY from the database.
 * @param testDataDirectory The test data directory where the result of the COPY is stored.
 * @param tableName The name of the table which is currently dumped from the database.
 *
 * @throws SQLException if the COPY command on the SQL server fails.
 * @throws IOException if the dump result could not be written successfully.
 */
private static void dumpTableInformation(
    final Connection connection, final File testDataDirectory, final String tableName)
        throws SQLException, IOException {
  final CopyManager manager = new CopyManager((BaseConnection) connection);
  try (FileWriter fw = new FileWriter(new File(testDataDirectory, tableName + ".sql"))) {
    manager.copyOut("COPY " + tableName + " TO STDOUT", fw);
  } catch (final IOException exception) {
    CUtilityFunctions.logException(exception);
  } 
}
 
开发者ID:google,项目名称:binnavi,代码行数:22,代码来源:IntegrationTestSetup.java

示例15: getCopyAPI

import org.postgresql.copy.CopyManager; //导入依赖的package包/类
/**
 * This returns the COPY API for the current connection.
 * @since 8.4
 */
public CopyManager getCopyAPI() throws SQLException;
 
开发者ID:health-and-care-developer-network,项目名称:health-and-care-developer-network,代码行数:6,代码来源:PGConnection.java


注:本文中的org.postgresql.copy.CopyManager类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。