Перейти из форума на сайт.

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Вопросы по компонентам для Delphi, C++ Builder разных версий

Модерирует : ShIvADeSt

ShIvADeSt (26-06-2017 02:39): Продолжение тут
http://forum.ru-board.com/topic.cgi?forum=33&topic=14667
 Версия для печати • ПодписатьсяДобавить в закладки
Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411

   

ShIvADeSt



Moderator
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Продолжение раздела http://forum.ru-board.com/topic.cgi?forum=33&topic=6607&start=0  
Ссылки приветствуются.

См. также:

Всего записей: 3956 | Зарегистр. 29-07-2003 | Отправлено: 07:33 20-06-2007 | Исправлено: XPerformer, 14:41 24-10-2013
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Не подскажет ли кто такой момент - для подключения к БД используются UniDac, нужно сделать обновление базы , например путем сравнения с эталонной базой, про Clever компоненты в курсе, но они не поддерживают подключения UniDac, может есть у кого другие идеи?

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 18:31 23-04-2014
G787



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
miwa
Спасибо.
 
 

Всего записей: 1035 | Зарегистр. 04-12-2005 | Отправлено: 18:56 23-04-2014
ant0ni02004

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok
или заглушку-переходник написать, или сравнивать SQL/DDL скрипты
но обновление БД в автоматическом режиме - вещь опасная вообще-то

Всего записей: 442 | Зарегистр. 26-10-2004 | Отправлено: 23:49 23-04-2014
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
ant0ni02004 Что тут опасного? сначала автоматом бекапим бд, потом обновляем, или предлагаешь 200 клиентов руками обновлять?
 
 
Добавлено:
Нет ли какой приблуды к Uni дак для обновления бд?

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 00:22 24-04-2014
miwa

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok
Сравнение с эталоном - фиговый вариант. База данных должна создаваться из скриптов и обновление - это последовательное выполнение скриптов для приведения состояния базы с версии А.В.С в версию X.Y.Z.
 
Кроме прочего, это даст возможность кроме обновления метаданных обновлять еще и данные, заполнять свежесозданные таблицы дефолтными значениями и делать все остальное, что может целевая СУБД.
 
Плюс возможность использования системы контроля версий для хранения скриптов-обновлений тоже не стоит сбрасывать со счетов.

Всего записей: 455 | Зарегистр. 10-10-2004 | Отправлено: 01:41 24-04-2014
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
miwa Все это понятно, но в моем случае не нужно заполнять данными никакие таблицы, причем обновление должно быть по схеме : например из состояния В сразу в состояние Z . т.е. всегда при обнове выполняется обновление до последней версии, думаю хранить истории из скриптов версий X, Y, Z - более чем неудобно, причем тогда еще нужно отслеживать в каком состоянии в данный момент база клиента - например А или С и соответственно применять нужные скрипты.

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 07:28 24-04-2014
neznayka3

Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok
не получится. у клиентов будут разные версии программы/бд A,B,C..G и всем надо в Z. если клиент можно просто заменить, то для обновления бд, надо знать с какого места ее обновлять.

Всего записей: 385 | Зарегистр. 07-06-2007 | Отправлено: 08:27 24-04-2014
Andryshok



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
neznayka3 Я же говорю про библиотеку Database Comparer VCL, если ее использовать то не нужно знать какая версия БД у клиента - компонент сравнивает эталонную БД (которую например можно также загрузить клиенту при выполнении обновы например если БД в одном файле - Firebird тот же) или эталонный выгруженный скрипт всей БД и на выходе либа дает результирующий скрипт обновления всей БД который просто нужно выполнить и все, без разницы какая там версия у клиента ...  он сразу получит последнюю версию,  но в моем случае нет коннектора UniDac для Database Comparer VCL,.

Всего записей: 649 | Зарегистр. 03-06-2009 | Отправлено: 08:33 24-04-2014
OXDBA

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok
Добавь столбец с ограничением NOT NULL в эталон, запусти  Database Comparer, проверь скрипт на предмет
 заполнения этого поля значениями по умолчанию.

Всего записей: 426 | Зарегистр. 19-01-2005 | Отправлено: 09:06 24-04-2014
jonikDk



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok
Тебе правильно посоветовал miwa. Хочешь обновлять - обновляй скриптами. Это самоё надежное и проверенное решение.
Если не помнишь какая версия у клиентов - заведи дополнительные таблицы, в которых сохраняй имена всех выполненных скриптов или имя пакета скриптов - вариантов несколько.
А то что ты хочешь - это не вариант обновления, это потенциальный вариант сломать БД

Всего записей: 1603 | Зарегистр. 01-03-2004 | Отправлено: 09:07 24-04-2014
Kmich



Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok
у меня обновление реализовано скриптами
например добавали таблицу или изменили длину поля я копирую SQL скрипт в конец текстового файла и при следующем обновлении отправляю программу и в папке Update файлик. Программа при запуске подхватывает этот файлик и выполняет скрипт.  У меня одни и теже обновления могут выполняться по 100 раз а вся нагрузка на Firebird он сам отслеживает есть ли поле в таблице или нет, соответственно если есть  такое поле или таблица то ошибку выдает и я делаю откат.  
Единственная проблема может возникнуть если уникальные ключи менять или менять тип поля или длину по несколько раз. прога работает на 250 машинах, главное чтобы клиенты обновление получили/скачали.

Всего записей: 192 | Зарегистр. 21-01-2005 | Отправлено: 11:14 24-04-2014
OXDBA

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Kmich

Цитата:
Программа при запуске подхватывает этот файлик и выполняет скрипт.

Остальные клиенты, подключенные к базе, об изменении метаданных узнают телепатически?

Всего записей: 426 | Зарегистр. 19-01-2005 | Отправлено: 11:30 24-04-2014
miwa

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Andryshok

Цитата:
в моем случае не нужно заполнять данными никакие таблицы,

Гарантированно никогда? Никогда не будет новых not null столбцов? Никогда не появится новый справочник с эталонными значениями? Никогда не надо будет провести денормализацию на основании уже имеющихся значений?
 
Не смешите мои тапочки ©
 

Цитата:
 обновление должно быть по схеме : например из состояния В сразу в состояние Z . т.е. всегда при обнове выполняется обновление до последней версии

А оно и так всегда будет обновляться до последней версии. Хранить в базе данных ее текущую версию и при поновлении запускать поочередно скрипты, которые сделают всю работу по обновлению.
 

Цитата:
хранить истории из скриптов версий X, Y, Z - более чем неудобно

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

Цитата:
причем тогда еще нужно отслеживать в каком состоянии в данный момент база клиента - например А или С и соответственно применять нужные скрипты.

Да, конечно, написать что-то типа (дельфи-псевдокод)
 

Код:
  FindFirst(*.sql, faAnyFile, CurrentFile);
  while FindNext(CurrentFile) do
    if GetVersion(CurrentFIle) > GetVersion(Database)
      then UpdateDbFromFile(CurrentFIle);
  FindClose(CurrentFile);
 

это значительно намного сложнее, чем написать коннесктор UniDAC для  Database Comparer VCL.
 
Kmich

Цитата:
У меня одни и теже обновления могут выполняться по 100 раз а вся нагрузка на Firebird он сам отслеживает есть ли поле в таблице или нет, соответственно если есть  такое поле или таблица то ошибку выдает и я делаю откат.  

А вот так я бы не советовал делать. Независимо от того, сам ли Firebird отслеживает, или Oracle, или MySQL какой-нибудь. Запросто можно нарваться на вариант типа: создать новый временный столбец,  
скопировать данные из существующего с каким-то изменением (хоть lowercase или смена кодировки для строк, хоть какой-нибудь +1900 для дат, хоть +1 для чисел), грохнуть старый столбец, на его место всунуть новый с измененными данными. Такой вариант всегда будет отрабатывать без ошибок и всегда будет менять данные. И это - только первое из того, что пришло в голову, не вникая в нюансы конкретной СУБД или предметной области.

Всего записей: 455 | Зарегистр. 10-10-2004 | Отправлено: 11:39 24-04-2014
OXDBA

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

Цитата:
А вот так я бы не советовал делать. Независимо от того, сам ли Firebird отслеживает, или Oracle, или MySQL какой-нибудь. Запросто можно нарваться на вариант типа: создать новый временный столбец  

Кстати, да

Цитата:
 У меня одни и теже обновления могут выполняться по 100 раз  

Здесь может сложиться ситуация, когда одни и те же обновления не выполнятся ни разу из 100.
Например для Firebird, так горячо любимый многими object is in use при создании FOREIGN KEY

Всего записей: 426 | Зарегистр. 19-01-2005 | Отправлено: 11:56 24-04-2014
Kmich



Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
OXDBA

Цитата:
Остальные клиенты, подключенные к базе, об изменении метаданных узнают телепатически?

у меня все проще прога работает Embeded локально на одном компутере.  
 
 
miwa

Цитата:
создать новый временный столбец,   скопировать данные из существующего с каким-то изменением (хоть lowercase или смена кодировки для строк, хоть какой-нибудь +1900 для дат, хоть +1 для чисел), грохнуть старый столбец, на его место всунуть новый с измененными данными.

 
Подобные манипуляции пока не проводил, у меня чаще бывает было поле 15 символов, а надо сделать 30 символов, или таблицу добавить новую или поле новое, которое  пользователи потом заполняют.  
и новые справочники  мелкие из 10-20 записей.  
 

Всего записей: 192 | Зарегистр. 21-01-2005 | Отправлено: 12:09 24-04-2014
NickNNN



Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Вставлю свои 5 копеек.
 
Я решил проблему с обновлением базы так:
 
1. В программе хранится скрипт, выполняющий обновление от самой первой версии до текущей
2. В базе хранится текущий номер версии базы
3. В программе хранится номер актуальной версии базы
5. Если 2 и 3 не совпадают, при запуске программа обновляет базу
6. Если возникает исключение при открытии таблиц базы, скрипт обновления выполняется принудительно

Всего записей: 156 | Зарегистр. 25-11-2008 | Отправлено: 12:13 24-04-2014
deks



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Из своего опыта поддержку miwa! Его способ со скриптами только кажется громоздким. Но именно он дает НЕОБХОДИМУЮ гибкость процессу разработки.
 
Я вот только разбиваю скрипты создания БД на части - в первой части объявления доменов, дальше DDL создания табличек, дальше - первичные ключи, дальше - вторичные. Где-то рядом висят скрипты для заполнения seed данными (начальные данные для таблицы - например, для справочника стран заполнены страны СНГ), причем есть разные наборы seed данных - для production и для различных test cases. Удобно комбинировать чего тебе нужно - создал таблицы, залил данные - накатил ключи и индексы.  
 
В продакшене максимально удобно делать апгрейд скриптом с административной машины - отключить всех клиентов, бэкап, и апгрейд - скрипт за скриптом. Часть скриптов может добавлять новые таблички с seed данными. Часть скриптов может мигрировать таблицы к новому формату при апгрейде структуры (нормализация/денормализация и тп).
 
пс: Забыл добавить, что при разработке я предпочитаю часто убивать БД и создавать ее заново с тестовыми данными. А для тестов БД вообще может создаваться для каждой пачки тестов своя - при прогоне тестов. Я просто тестами часто баги оформляю по факту фикса - слежу чтобы не было регрессий, тесты улучшаю (иногда баги проявляются только на определенном наборе данных, вот такие баги и рождают дополнительный test).

Всего записей: 857 | Зарегистр. 09-10-2003 | Отправлено: 13:33 24-04-2014 | Исправлено: deks, 13:37 24-04-2014
NickNNN



Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
deks, я ничего не разбивал. Код обновления базы выглядит следующим образом:
 

Код:
 
 
    UpdateBase(1, 'CREATE TABLE LAMTYPES (ID DID,NAME DNAME,ZVALUE  DID);');
    UpdateBase(1, 'ALTER TABLE LAMTYPES ADD CODE DID;');
    UpdateBase(1, 'ALTER TABLE LAMTYPES ADD PID DNAME255;');
    UpdateBase(1, 'ALTER TABLE LAMTYPES ADD BColor DID;');
 
 

 
Уже внутри процедуры решается выполнять SQL команду сейчас или база уже обновлена.
10 лет работает как часы. Запустив новую сборку программы на старой базы получаем обновление до текущей версии

Всего записей: 156 | Зарегистр. 25-11-2008 | Отправлено: 13:39 24-04-2014
OXDBA

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
deks
Мы используем аналогичный подход. В update, как правило, входят два скрипта. DDL и DML отдельно.
NickNNN

Цитата:
Запустив новую сборку программы на старой базы получаем обновление до текущей версии  

Мы отказались от хранения скриптов внутри программы после обновления зоопарка из разных версий БД, работающих под управлением разных версий FB. Один из заказчиков упорно отказывался обновлять старые объекты на FB 2.1.

Всего записей: 426 | Зарегистр. 19-01-2005 | Отправлено: 13:58 24-04-2014
miwa

Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
deks
Вот кстати по тестам весьма интересный вопросс - каким образом они у тебя пишутся/работают? Используются ли какие-то внешние инструменты? Есть ли какие-то внутрение универсальные обвязки?  
 
Я как раз думаю над тестированием базы ибо достали регрессии, но ничего умнее пары таблиц типа

Код:
 
create table test_texts(
  id integer,
  codename varchar(30),
  sql_text varchar(32000)
);
create table test_results(
  test_id integer,
  test_result integer,
  test_duration time
);
 

с последующим запуском всего что есть в test_texts через execute block (мы же все здесь о Firebird говорим, правда? ) не придумал.

Всего записей: 455 | Зарегистр. 10-10-2004 | Отправлено: 14:00 24-04-2014
   

Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411

Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Вопросы по компонентам для Delphi, C++ Builder разных версий
ShIvADeSt (26-06-2017 02:39): Продолжение тут
http://forum.ru-board.com/topic.cgi?forum=33&topic=14667


Реклама на форуме Ru.Board.

Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
Modified by Ru.B0ard
© Ru.B0ard 2000-2024

BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

Рейтинг.ru