Hive - Utwórz bazę danych
Hive to technologia baz danych, która umożliwia definiowanie baz danych i tabel w celu analizy danych strukturalnych. Tematem analizy danych strukturalnych jest przechowywanie danych w sposób tabelaryczny i przekazywanie zapytań w celu ich analizy. W tym rozdziale wyjaśniono, jak utworzyć bazę danych Hive. Hive zawiera domyślną bazę danych o nazwiedefault.
Utwórz instrukcję bazy danych
Utwórz bazę danych to instrukcja używana do tworzenia bazy danych w programie Hive. Baza danych w Hive to pliknamespacelub zbiór tabel. Pliksyntax dla tego stwierdzenia jest następująca:
CREATE DATABASE|SCHEMA [IF NOT EXISTS] <database name>
W tym przypadku IF NOT EXISTS to opcjonalna klauzula, która powiadamia użytkownika, że baza danych o tej samej nazwie już istnieje. Możemy użyć SCHEMA zamiast DATABASE w tym poleceniu. Następujące zapytanie jest wykonywane w celu utworzenia bazy danych o nazwieuserdb:
hive> CREATE DATABASE [IF NOT EXISTS] userdb;
or
hive> CREATE SCHEMA userdb;
Następujące zapytanie służy do weryfikacji listy baz danych:
hive> SHOW DATABASES;
default
userdb
Program JDBC
Poniżej przedstawiono program JDBC do tworzenia bazy danych.
import java.sql.SQLException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.sql.DriverManager;
public class HiveCreateDb {
private static String driverName = "org.apache.hadoop.hive.jdbc.HiveDriver";
public static void main(String[] args) throws SQLException {
// Register driver and create driver instance
Class.forName(driverName);
// get connection
Connection con = DriverManager.getConnection("jdbc:hive://localhost:10000/default", "", "");
Statement stmt = con.createStatement();
stmt.executeQuery("CREATE DATABASE userdb");
System.out.println(“Database userdb created successfully.”);
con.close();
}
}
Zapisz program w pliku o nazwie HiveCreateDb.java. Poniższe polecenia służą do kompilowania i wykonywania tego programu.
$ javac HiveCreateDb.java
$ java HiveCreateDb
Wynik:
Database userdb created successfully.