![]() |
Модераторы: LSD, AntonSaburov |
![]() ![]() ![]() |
|
Nestor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 26 Регистрация: 15.4.2007 Где: Одесса Репутация: нет Всего: 1 |
Здравия!
С подключением к уже существующей бд из java-приложения у меня проблем нет. Но мне нужно подключится к серверу, при этом не подключаясь к определенной БД, и создать новую БД. В дальнейшем программа должна в зависимости от того, существует ли БД, либо создавать, либо подключаться к существующей. Проблема в том, что мне никак не удается подключится к серверу, не указывая БД. Поиск конкретного примера такого подключения не дал. Надеюсь на вашу помощь. Подключение к БД я осуществляю следующим образом:
Это сообщение отредактировал(а) Nestor - 9.4.2008, 15:02 |
|||
|
||||
ekr |
|
|||
![]() ...и это пройдет... ![]() ![]() Профиль Группа: Участник Сообщений: 359 Регистрация: 6.5.2007 Где: Moscow, RU Репутация: 3 Всего: 19 |
А в постгресе нет ли флажка, как в других СУБД, типа:
|
|||
|
||||
Nestor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 26 Регистрация: 15.4.2007 Где: Одесса Репутация: нет Всего: 1 |
Да действительно, в документации postgresql надо было копаться...
Покопался, однако, подобного параметра я все же не нашел... А смотрел в след. файле Присоединённый файл ( Кол-во скачиваний: 11 ) ![]() |
|||
|
||||
mbasil |
|
|||
Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 399 Регистрация: 4.5.2007 Где: Москва Репутация: 2 Всего: 13 |
Можно сделать несколько попыток подключения (для верности) к конкретной базе, перехватывая исключения подключения, а затем при получении, в конечном счете неудачи, создать оную базу.
|
|||
|
||||
Nestor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 26 Регистрация: 15.4.2007 Где: Одесса Репутация: нет Всего: 1 |
Это совет, как определить, существует ли база с конкретным именем? Если да, то для этого есть способ проще. Или же я Вас просто не понял. |
|||
|
||||
tux |
|
|||
![]() Летатель ![]() ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 1853 Регистрация: 10.2.2005 Где: msk.ru Репутация: 31 Всего: 132 |
Nestor, вопрос несколько не в тему. Как правило, если нужны несколько пространств одной и той же схемы данных, используют схемы PostgreSQL - http://www.postgresql.org/docs/8.3/interac...eateschema.html. Я ни разу не сталкивался с ситуацией когда нужно создавать базу. Можешь описать задачу?
|
|||
|
||||
mbasil |
|
|||
Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 399 Регистрация: 4.5.2007 Где: Москва Репутация: 2 Всего: 13 |
Точно, tux прав. Я работаю в Oracle и создание базы данных это сложный и дорогостоящий процесс. Немыслимо себе представить, чтобы база данных создавалась по запросу пользователя. В случае какой либо простейшей базы, например, Derby, это возможно.
Впрочем, в Oracle я бы даже создание схемы не доверил пользователю, поскольку это задача администратора, который делает это по запросу пользователя или разработчика. Дай пользователю возможность создавать и найдется такой, который злонамеренно создаст что-то разрушительное. |
|||
|
||||
skif18 |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 358 Регистрация: 17.5.2007 Где: Молдова, Кишинев Репутация: нет Всего: 1 |
Создать на Postgres базу кодом по моему нельзя. Читал где-то. но давно было так что могло и измениться. Поищу. Ответ выложу или ссылку.
-------------------- |
|||
|
||||
Nestor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 26 Регистрация: 15.4.2007 Где: Одесса Репутация: нет Всего: 1 |
Получилось создать следующим образом.
Насколько я понимаю, в каждом Postresql есть неудаляемая БД под названием "postgres". Сначала подключаемся к ней, из полученного Connection посылаем запрос на создание своей БД, подключаемся к новосозданной БД. Что касается того, в каких ситуациях это нужно и нужно ли вообще - не мне судить. Проект не реальный, а учебный, учим в вузе БД на примере Postgres'а. В настоящих проектах, наверное, как отметили tux и mbasil, такие вещи делать часто не приходится. |
|||
|
||||
tux |
|
|||
![]() Летатель ![]() ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 1853 Регистрация: 10.2.2005 Где: msk.ru Репутация: 31 Всего: 132 |
Это верно начиная с определенной версии PostgreSQL (не помню какой). В любом случае база создается простым копированием файлов существующей базы данных, синтаксис команды создания БД даже дает возможность какую существующую базу использоваться для копирования. По дефолту если ничего не указать, используется база с именем template1. Вот ее вероятно и стоит использовать в качестве объекта подключения. Тем не менее, любую базу (и template1 в том числе) можно удалить. |
|||
|
||||
Nestor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 26 Регистрация: 15.4.2007 Где: Одесса Репутация: нет Всего: 1 |
tux
Понятно. Я просто подключаюсь на template1, затем опять же используя полученный Connection создаю нужную базу. Я так понимаю, заполнять template1, чтобы потом создать новую БД, копируя в нее содержимое, не имеет смысла, когда можно заполнять сразу нужную БД. То есть преимущество подключения к "template1" (над подключением к "postgres"), заключается в том, что это пройдет на всех версиях Postgres'а. Я правильно понял Вашу идею? PS Моя программа ни из какой БД данные не берет, и пользователем они не вводятся. Она сама знает, какую структуру базы нужно создать, чем ее заполнить (в соответствии с содержимым жесткого диска) и в дальнейшем как ее использовать. Это на всякий случай. ![]() |
|||
|
||||
tux |
|
|||
![]() Летатель ![]() ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 1853 Регистрация: 10.2.2005 Где: msk.ru Репутация: 31 Всего: 132 |
||||
|
||||
Nestor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 26 Регистрация: 15.4.2007 Где: Одесса Репутация: нет Всего: 1 |
Тогда на этом все. Всем спасибо.
|
|||
|
||||
![]() ![]() ![]() |
Правила форума "Java" | |
|
Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic. |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Java: Общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |