Мы создали Java-приложение, которое использует базу данных JavaDB в среде IDE Netbeans. Мы хотим, чтобы программа при каждом запуске проверяла, созданы ли уже таблицы базы данных, и в противном случае создавала их. Как мы это делаем? спасибо
JavaDB — проверка существования базы данных
comment
возможный дубликат Как проверить, существует ли база данных в Hsqldb /Дерби?
- person Raedwald   schedule 02.09.2013
comment
ответ чесночника правильный, только я добавляю, что поиск в таблице должен быть в верхнем регистре, потому что, несмотря на то, что вы создали свою таблицу в нижнем регистре, метаданные в верхнем регистре
- person Marco Van   schedule 10.07.2017
Ответы (2)
Я использую :
DatabaseMetaData metas;
ResultSet tables;
Statement stat;
m_connexion = DriverManager.getConnection("jdbc:derby:mybase;create=true");
metas = m_connexion.getMetaData();
stat = m_connexion.createStatement();
tables = metas.getTables(m_connexion.getCatalog(), null, "MYTABLE", null);
if (!tables.next())
stat.execute(
"CREATE TABLE APP.MYTABLE (" // etc.
... и это работа для меня.
person
Istao
schedule
12.08.2010
Тест Истао на существование таблицы не работал у меня с Дерби. Таблица так и не была найдена, хотя она была создана ранее. Чего не хватает, так это указать TABLE_SCHEM как «APP», а затем установить тип таблицы, чтобы включить «TABLE». Возможно, использование null работало в предыдущих версиях, но использование Derby 10.12 не находит ранее созданную таблицу с этими параметрами, установленными на null.
Connection conn = DriverManager.getConnection(DB_PROTO + DB_NAME + ";create=true");
DatabaseMetaData metas = conn.getMetaData();
ResultSet tables = metas.getTables(conn.getCatalog(), "APP", TABLE_NODES, new String[] {"TABLE"});
if (!tables.next()) {
Statement stat = conn.createStatement();
stat.execute("create table " + ...
Надеюсь, это поможет кому-то еще.
person
dubmojo
schedule
24.06.2016