powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Java [игнор отключен] [закрыт для гостей] / Абстракция над БД
13 сообщений из 13, страница 1 из 1
Абстракция над БД
    #38509562
r.nik.
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Добрый день!
Я хочу странного. Мне нужно что-то типа ORM, но чтоб при изменении структуры не приходилось перекомпилировать приложение (пакет), а достаточно было просто поменять конфиги.

Отвечаю на резонный вопрос, как я это вижу:
Код: java
1.
2.
Map<String, String> row = getRow();
magicObject->save(row);



Так же хотелось, чтоб с отдельного пинка оно могло удалять, создавать таблицы.

Требуется поддержка трёх БД: MS Sql, MySql, postgreSQL.
Спасибо тем, кто ответит.
...
Рейтинг: 0 / 0
Абстракция над БД
    #38509569
Фотография Павел Воронцов
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
r.nik.,

Не делай так. Возьми Хибернейт и подумай над структурой данных.
...
Рейтинг: 0 / 0
Абстракция над БД
    #38509582
r.nik.
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Павел Воронцов,

Всё конечно так, как Вы сказали. Но программа не большая и отчуждаемая и тут появляется несколько моментов:
1. Стурктура данных навязана и будет меняться абсолютно точно.
2. Всё остальное в программе достаточно просто конфигурируется, кроме структуры базы данных. И мне кажется это косяком.
3. Программа сама очень маленькая и хибирнейт займёт больше места на диске, чем сама программа со всеми остальными зависимостями.

Конечно я могу по желанию клиента менять структуру, компилить пакет за ново и отправлять и даже делать это за деньги, но это не та работа, на которой можно много зароботать.
...
Рейтинг: 0 / 0
Абстракция над БД
    #38510446
Фотография -=*ShamaN*=-
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
r.nik.Павел Воронцов,

Всё конечно так, как Вы сказали. Но программа не большая и отчуждаемая и тут появляется несколько моментов:
1. Стурктура данных навязана и будет меняться абсолютно точно.
2. Всё остальное в программе достаточно просто конфигурируется, кроме структуры базы данных. И мне кажется это косяком.
3. Программа сама очень маленькая и хибирнейт займёт больше места на диске, чем сама программа со всеми остальными зависимостями.

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

ИМХО, тут первого пункта достаточно для того, чтобы использовать ORM. На практике, меняется модель, и Вы видите, где-что поехало...
...
Рейтинг: 0 / 0
Абстракция над БД
    #38510450
Фотография Petro123
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
r.nik.1. Стурктура данных навязана и будет меняться абсолютно точно.
- ЧАСТО структура данных описывает Модель предметной области. Т.е. это неизменная часть.
Приведи пример обратного в сети.
...
Рейтинг: 0 / 0
Абстракция над БД
    #38510452
Фотография -=*ShamaN*=-
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
r.nik.... но это не та работа, на которой можно много зароботать.

Чтобы много заработать, нужно вечером после основной работы дома изучать, думать, изобретать, анализировать, планировать, делать, менять, взвешивать, оценивать и писать на SQL.ru))) если, конечно, Вы не "Сын Рокфеллера")))
...
Рейтинг: 0 / 0
Абстракция над БД
    #38510453
Фотография -=*ShamaN*=-
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Petro123r.nik.1. Стурктура данных навязана и будет меняться абсолютно точно.
- ЧАСТО структура данных описывает Модель предметной области. Т.е. это неизменная часть.
Приведи пример обратного в сети.

Petro, это нормально при отсутствии нормального аналитика...
...
Рейтинг: 0 / 0
Абстракция над БД
    #38510462
Фотография -=*ShamaN*=-
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
r.nik.Добрый день!
Я хочу странного. Мне нужно что-то типа ORM, но чтоб при изменении структуры не приходилось перекомпилировать приложение (пакет), а достаточно было просто поменять конфиги.

Отвечаю на резонный вопрос, как я это вижу:
Код: java
1.
2.
Map<String, String> row = getRow();
magicObject->save(row);



Так же хотелось, чтоб с отдельного пинка оно могло удалять, создавать таблицы.

Требуется поддержка трёх БД: MS Sql, MySql, postgreSQL.
Спасибо тем, кто ответит.

Нате вам лекарство
...
Рейтинг: 0 / 0
Абстракция над БД
    #38510466
Фотография Petro123
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
-=*ShamaN*=-,
конечно. Динамический SQL тоже считается моветоном разработки:
string = SELECT + Field + Name + FROM
ВыполнитьБД(string)
"Всё хорошо.... в меру"
...
Рейтинг: 0 / 0
Абстракция над БД
    #38510474
Фотография -=*ShamaN*=-
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
-=*ShamaN*=-r.nik.Добрый день!
Я хочу странного. Мне нужно что-то типа ORM, но чтоб при изменении структуры не приходилось перекомпилировать приложение (пакет), а достаточно было просто поменять конфиги.

Отвечаю на резонный вопрос, как я это вижу:
Код: java
1.
2.
Map<String, String> row = getRow();
magicObject->save(row);



Так же хотелось, чтоб с отдельного пинка оно могло удалять, создавать таблицы.

Требуется поддержка трёх БД: MS Sql, MySql, postgreSQL.
Спасибо тем, кто ответит.

Нате вам лекарство

Хм... я тут призадумался.... а ведь с этой штуковиной можно полностью динамический словарь данных построить, типа как в 1С и ему подобных. Но это должно остаться "под капотом".

Топик-стартеру на заметку: при динамической работе с моделями вы потеряете контроль, который производится компилятором в случае мапинга "Модель=Класс" в JPA.
Я хочу сказать, что конструкции вида
Код: java
1.
superRow.setFieldValue("address", newAddress);

при изменении модели (например, при переименовании колонки в addr) спокойно пройдут компиляцию, в то время как конструкция
Код: java
1.
user.setAddress(newAddress);

просто не скомпилируется, и вы увидите сразу все неликвидные обращения к модели при изменениях последней. Чтобы подобный контроль работал и при построении запросов, в JPA предусмотрены классы статической метамодели - это volatile описатели атрибутов модели, которые можно передавать в качестве аргументов.

Я не навязываю свой мнение, а лишь излагаю 2 подхода. Вам нужно 100500 раз подумать, нужно ли вам приходить к модели неконтролируемого датасета Delphi...
...
Рейтинг: 0 / 0
Абстракция над БД
    #38510475
Фотография -=*ShamaN*=-
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Petro123-=*ShamaN*=-,
конечно. Динамический SQL тоже считается моветоном разработки:
string = SELECT + Field + Name + FROM
ВыполнитьБД(string)
"Всё хорошо.... в меру"

Почти одновременно))))
...
Рейтинг: 0 / 0
Абстракция над БД
    #38510481
Фотография -=*ShamaN*=-
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Petro123-=*ShamaN*=-,
конечно. Динамический SQL тоже считается моветоном разработки:
string = SELECT + Field + Name + FROM
ВыполнитьБД(string)
"Всё хорошо.... в меру"

Petro, я с Вами абсолютно согласен, хреновый моветон...
Особенно, когда требуется наследование запросов - ну типа родительский Query одну таблицу селектит с фильтрами по полям, а наследники должны добавлять разные джойны или агрегаты.
...
Рейтинг: 0 / 0
Абстракция над БД
    #38510556
just_vladimir
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Мне кажется или автору нужен ORM использующий EAV модель... имхо, сомнительная штука, но раз хочется
...
Рейтинг: 0 / 0
13 сообщений из 13, страница 1 из 1
Форумы / Java [игнор отключен] [закрыт для гостей] / Абстракция над БД
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]