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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как лучше таблицы в базу данны 
:(
    Опции темы
jvoid
Дата 18.11.2009, 14:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Разработал базу в MySQL Workbench, хочу сделать класс который бы создавал базу данных при первом запуске приложения
копирую созданый ею SQL код

Код

CREATE  TABLE IF NOT EXISTS `lan`.`City` (
  `id` BIGINT NULL ,
  `idWord` BIGINT NULL ,
  `idTypeCity` BIGINT NULL ,
  `partOff` BIGINT NULL )
ENGINE = InnoDB


Вставляю полученный SQL в код:
Код

try {
            Class.forName("com.mysql.jdbc.Driver");
            String url = "jdbc:mysql://localhost:3306/lan";
            con = DriverManager.getConnection(url, "root", "1111");
            
            statement = con.createStatement();
            String table = "CREATE  TABLE IF NOT EXISTS `lan`.`City` (
  `id` BIGINT NULL ,
  `idWord` BIGINT NULL ,
  `idTypeCity` BIGINT NULL ,
  `partOff` BIGINT NULL )
ENGINE = InnoDB";
            statement.executeUpdate(table);

В таком виде он его не понимает, конечно можно в ручную переписать, но таблиц в базе уже около 60, как этот процесс ускорить?
PM MAIL   Вверх
Temdegon
Дата 18.11.2009, 21:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

Репутация: 7
Всего: 9



я бы записал SQL-команды в файл, разделив их строкой с каким-нибудь внятным комментарием, содержащим идентификатор, 
на пример '--//City', при загрузке прочитал бы файл и сложил бы их в коллекцию. Ну а оттуда бы уже брал в нужный момент нужый SQL по ключу. 
Хотя может есть более разумный подход к хранению SQL. В любом случае, не писать же их прямо в коде.
Конкретно для вашего случая, возможно есть какая-то команда, для исполнения SQL-файла, что бы одной командой прогнать сразу все запросы из файла. Вам ведь не нужно в запросы подставлять никаких параметров и обрабатывать результат. Тут в соседней ветке про парсинг sql было что-то похожее.
PM MAIL   Вверх
aleksandy
Дата 19.11.2009, 13:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

Репутация: 4
Всего: 5



Как минимум надо попробовать так
Код

            String table = "CREATE  TABLE IF NOT EXISTS " + "'lan'.'City' ( " + 
"  'id' BIGINT NULL ," + 
"  'idWord' BIGINT NULL ," + 
"  'idTypeCity' BIGINT NULL ," + 
"  'partOff' BIGINT NULL )" + 
"ENGINE = InnoDB";
            statement.executeUpdate(table);

А еще лучше без апострофов.
PM   Вверх
jvoid
Дата 19.11.2009, 16:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Код

Как минимум надо попробовать так

Ну это понятно, я ж говорю очень много SQL кода, просто так нужно вручную  писать. Можно каким то инструментом или скриптом переделать
Код

CREATE  TABLE IF NOT EXISTS `lan`.`City` (
  `id` BIGINT NULL ,
  `idWord` BIGINT NULL ,
  `idTypeCity` BIGINT NULL ,
  `partOff` BIGINT NULL )
ENGINE = InnoDB

в 
Код

"CREATE  TABLE IF NOT EXISTS " + "'lan'.'City' ( " + 
"  'id' BIGINT NULL ," + 
"  'idWord' BIGINT NULL ," + 
"  'idTypeCity' BIGINT NULL ," + 
"  'partOff' BIGINT NULL )" + 
"ENGINE = InnoDB";

Или по существующей базе данных сгенерировать java код который можно для создания БД использовать

PM MAIL   Вверх
aleksandy
Дата 20.11.2009, 06:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

Репутация: 4
Всего: 5



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

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

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


 




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


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

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