package net.jaekl.cfb.db;
+// Copyright (C) 2015 Christian Jaekl
+
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.ResultSet;
String m_name;
DbDriver m_driver;
ArrayList<Table> m_tables;
+ ArrayList<Sequence> m_sequences;
public Schema(String name, DbDriver driver) {
m_name = name;
m_driver = driver;
m_tables = new ArrayList<Table>();
+ m_sequences = new ArrayList<Sequence>();
}
public boolean ensureDbInitialized(Connection con) throws SQLException {
return false;
}
+ if (!createAllSequences(con)) {
+ return false;
+ }
+
+ if (!postCreationInit(con)) {
+
+ }
+
+ return true;
+ }
+
+ boolean postCreationInit(Connection con) throws SQLException {
+ // no-op
+ // Override this in a derived class if you need to initialize something
+ // after the tables and sequences are created.
return true;
}
return true;
}
+ boolean createAllSequences(Connection con) throws SQLException {
+ for (Sequence seq : m_sequences) {
+ if (!m_driver.createSequence(con, seq)) {
+ return false;
+ }
+ }
+ return true;
+ }
+
void addTable(Table table) {
m_tables.add(table);
}
// { table_name },
// { column_name, type, width (-1 for default), null/not_null }
// }
- void addTables(Object[][][] tables)
+ void addTables(Table[] tables)
{
- for (Object[][] table : tables) {
- addTable(Table.construct(table));
+ for (Table table : tables) {
+ addTable(table);
+ }
+ }
+
+ void addSequence(Sequence seq) {
+ m_sequences.add(seq);
+ }
+
+ void addSequences(Sequence[] sequences) {
+ for (Sequence sequence : sequences) {
+ addSequence(sequence);
}
- }
+ }
}