Example usage for com.amazonaws.services.glue.model CreateDatabaseRequest CreateDatabaseRequest

List of usage examples for com.amazonaws.services.glue.model CreateDatabaseRequest CreateDatabaseRequest

Introduction

In this page you can find the example usage for com.amazonaws.services.glue.model CreateDatabaseRequest CreateDatabaseRequest.

Prototype

CreateDatabaseRequest

Source Link

Usage

From source file:com.facebook.presto.hive.metastore.glue.GlueHiveMetastore.java

License:Apache License

@Override
public void createDatabase(Database database) {
    if (!database.getLocation().isPresent() && defaultDir.isPresent()) {
        String databaseLocation = new Path(defaultDir.get(), database.getDatabaseName()).toString();
        database = Database.builder(database).setLocation(Optional.of(databaseLocation)).build();
    }/*ww  w.  j  a v a  2s  .  c o m*/

    try {
        DatabaseInput databaseInput = GlueInputConverter.convertDatabase(database);
        glueClient.createDatabase(new CreateDatabaseRequest().withDatabaseInput(databaseInput));
    } catch (AlreadyExistsException e) {
        throw new SchemaAlreadyExistsException(database.getDatabaseName());
    } catch (AmazonServiceException e) {
        throw new PrestoException(HIVE_METASTORE_ERROR, e);
    }

    if (database.getLocation().isPresent()) {
        HiveWriteUtils.createDirectory(hdfsContext, hdfsEnvironment, new Path(database.getLocation().get()));
    }
}