Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Подключение к SQL-серверу и создание новой БД, PostgreSql 
V
    Опции темы
Nestor
Дата 9.4.2008, 14:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 26
Регистрация: 15.4.2007
Где: Одесса

Репутация: нет
Всего: 1



Здравия!
С подключением к уже существующей бд из java-приложения у меня проблем нет. Но мне нужно подключится к серверу,  при этом не подключаясь к определенной БД, и создать новую БД. В дальнейшем программа должна в зависимости от того, существует ли БД, либо создавать, либо подключаться к существующей. Проблема в том, что мне никак не удается подключится к серверу, не указывая БД. Поиск конкретного примера такого подключения не дал. Надеюсь на вашу помощь.

Подключение к БД я осуществляю следующим образом:
Код

Connection con = DriverManager.getConnection(
     "jdbc:postgresql://localhost/MyDatabase",
      "user",
      "password");


Это сообщение отредактировал(а) Nestor - 9.4.2008, 15:02
PM MAIL   Вверх
ekr
Дата 9.4.2008, 15:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


...и это пройдет...
**


Профиль
Группа: Участник
Сообщений: 359
Регистрация: 6.5.2007
Где: Moscow, RU

Репутация: 3
Всего: 19



А в постгресе нет ли флажка, как в других СУБД, типа:
Код

Connection con = DriverManager.getConnection(
     "jdbc:postgresql://localhost/MyDatabase;create=true",
      "user",
      "password");



--------------------
и это пройдет....

http://ekrs.blogspot.com
PM WWW   Вверх
Nestor
Дата 9.4.2008, 15:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 26
Регистрация: 15.4.2007
Где: Одесса

Репутация: нет
Всего: 1



Да действительно, в документации postgresql надо было копаться...
Покопался, однако, подобного параметра я все же не нашел...
А смотрел в след. файле

Присоединённый файл ( Кол-во скачиваний: 11 )
Присоединённый файл  postgresql_connect.zip 3,52 Kb
PM MAIL   Вверх
mbasil
Дата 9.4.2008, 15:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 399
Регистрация: 4.5.2007
Где: Москва

Репутация: 2
Всего: 13



Можно сделать несколько попыток подключения (для верности) к конкретной базе, перехватывая исключения подключения, а затем при получении, в конечном счете неудачи, создать оную базу.
PM MAIL   Вверх
Nestor
Дата 9.4.2008, 19:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 26
Регистрация: 15.4.2007
Где: Одесса

Репутация: нет
Всего: 1



Цитата(mbasil @  9.4.2008,  15:49 Найти цитируемый пост)
Можно сделать несколько попыток подключения (для верности) к конкретной базе, перехватывая исключения подключения, а затем при получении, в конечном счете неудачи, создать оную базу. 

Это совет, как определить, существует ли база с конкретным именем? Если да, то для этого есть способ проще. Или же я Вас просто не понял.
PM MAIL   Вверх
tux
Дата 10.4.2008, 06:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 31
Всего: 132



Nestor, вопрос несколько не в тему. Как правило, если нужны несколько пространств одной и той же схемы данных, используют схемы PostgreSQL - http://www.postgresql.org/docs/8.3/interac...eateschema.html. Я ни разу не сталкивался с ситуацией когда нужно создавать базу. Можешь описать задачу?
PM MAIL Skype GTalk Jabber YIM   Вверх
mbasil
Дата 10.4.2008, 10:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 399
Регистрация: 4.5.2007
Где: Москва

Репутация: 2
Всего: 13



Точно, tux прав. Я работаю в Oracle и создание базы данных это сложный и дорогостоящий процесс. Немыслимо себе представить, чтобы база данных создавалась по запросу пользователя. В случае какой либо простейшей базы, например, Derby, это возможно. 
Впрочем, в Oracle я бы даже создание схемы не доверил пользователю, поскольку это задача администратора, который делает это по запросу пользователя или разработчика. Дай пользователю возможность создавать и найдется такой, который злонамеренно создаст что-то разрушительное.
PM MAIL   Вверх
skif18
Дата 10.4.2008, 16:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 358
Регистрация: 17.5.2007
Где: Молдова, Кишинев

Репутация: нет
Всего: 1



Создать на Postgres базу кодом по моему нельзя. Читал где-то. но давно было так что могло и измениться. Поищу. Ответ выложу или ссылку.


--------------------

PM MAIL ICQ   Вверх
Nestor
Дата 10.4.2008, 17:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 26
Регистрация: 15.4.2007
Где: Одесса

Репутация: нет
Всего: 1



Получилось создать следующим образом.
Насколько я понимаю, в каждом Postresql есть неудаляемая БД под названием "postgres". Сначала подключаемся к ней, из полученного Connection посылаем запрос на создание своей БД, подключаемся к новосозданной БД.

Что касается того, в каких ситуациях это нужно и нужно ли вообще - не мне судить. Проект не реальный, а учебный, учим в вузе БД на примере Postgres'а. В настоящих проектах, наверное, как отметили tux и mbasil, такие вещи делать часто не приходится.
PM MAIL   Вверх
tux
Дата 11.4.2008, 05:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 31
Всего: 132



Цитата(Nestor @  10.4.2008,  17:59 Найти цитируемый пост)
в каждом Postresql есть неудаляемая БД под названием "postgres"

Это верно начиная с определенной версии PostgreSQL (не помню какой). В любом случае база создается простым копированием файлов существующей базы данных, синтаксис команды создания БД даже дает возможность какую существующую базу использоваться для копирования. По дефолту если ничего не указать, используется база с именем template1. Вот ее вероятно и стоит использовать в качестве объекта подключения. Тем не менее, любую базу (и template1 в том числе) можно удалить.
PM MAIL Skype GTalk Jabber YIM   Вверх
Nestor
Дата 11.4.2008, 15:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 26
Регистрация: 15.4.2007
Где: Одесса

Репутация: нет
Всего: 1



tux
Понятно. Я просто подключаюсь на template1, затем опять же используя полученный Connection создаю нужную базу. Я так понимаю, заполнять template1, чтобы потом создать новую БД, копируя в нее содержимое, не имеет смысла, когда можно заполнять сразу нужную БД. То есть преимущество подключения к "template1" (над подключением к "postgres"), заключается в том, что это пройдет на всех версиях Postgres'а. Я правильно понял Вашу идею?

PS Моя программа ни из какой БД данные не берет, и пользователем они не вводятся. Она сама знает, какую структуру базы нужно создать, чем ее заполнить (в соответствии с содержимым жесткого диска) и в дальнейшем как ее использовать. Это на всякий случай. smile 
PM MAIL   Вверх
tux
Дата 12.4.2008, 06:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Летатель
***


Профиль
Группа: Участник Клуба
Сообщений: 1853
Регистрация: 10.2.2005
Где: msk.ru

Репутация: 31
Всего: 132



Цитата(Nestor @  11.4.2008,  15:04 Найти цитируемый пост)
То есть преимущество подключения к "template1" (над подключением к "postgres"), заключается в том, что это пройдет на всех версиях Postgres'а. Я правильно понял Вашу идею?

Все верно. Насчет всех версий точно не скажу, но начиная с 6-ой и выше точно будет работать. 
PM MAIL Skype GTalk Jabber YIM   Вверх
Nestor
Дата 12.4.2008, 14:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 26
Регистрация: 15.4.2007
Где: Одесса

Репутация: нет
Всего: 1



Тогда на этом все. Всем спасибо.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1247 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.