169 похожих чатов

Всем привет. Подскажите, пожалуйста, бест прэктис. Есть витринка. Может быть

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

Нужно ли создавать какой-то скрипт на alter table или это можно делать просто ручками и не заморачиваться над автоматизацией?

10 ответов

8 просмотров

А без скрипта вы планируете каким-то средством визуального дизайна схемы обойтись? Вы поднимаете, что оно сгенерирует скрипт и выполнит его? При этом вы не будете на 100 процентов уверены в том, что именно оно будет делать, не видя кода скрипта. У вас должен быть какой-то тестовый/staging инстанс для таких экспериментов для начала. И скрипты миграции состояния схемы и данных от одной версии до другой

Nikita-Sysoev Автор вопроса
Roman Sergeev
А без скрипта вы планируете каким-то средством виз...

То есть проще ручками делать, чем писать скрипт?

Вы работаете с клиентскими данными. Ваша задача делать не проще, а лучше. Основными приоритетами должны быть сохранность данных и непрерывность предоставления сервисов, с ними связанных. Лучше написать тривиальный скрипт ручками. Если это пока вызывает сложности, то воспользуйтесь такой средой управления бд и схемами, которая умеет их генерировать. Изучите результат и превратите в свой скрипт. Визуальный дизайнер может вместо alter сделать drop + create. Для схемы разницы нет. Для данных - очень большая.

Roman Sergeev
Вы работаете с клиентскими данными. Ваша задача де...

Да, но добавление поля не вызывает drop+create. По крайне мере, SSMS. Подобное случается при изменении типа поля. И SSMS в этом случае создаёт временную таблицу, в которую переливает данные, а затем переименовывает, убивая старую таблицу.

Tim Safari
Да, но добавление поля не вызывает drop+create. По...

Если поле добавляется в конце то не вызывает.

Tim Safari
Да, но добавление поля не вызывает drop+create. По...

Вы же узнали это из результатов анализа скрипта, созданного ssms? Не с продом экспериментировали? Я знаю, что генерирует ssms - 13 лет с mssql работал. Но нам не было сказано ничего ни про базу, ни про средства управления. И все равно я это с mssql делал скриптами

Nikita-Sysoev Автор вопроса

Похожие вопросы

Обсуждают сегодня

Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
40
Проблема с Windows scripting control Множество объектов получают iDispatch обертки и отдаются в скрипты. При этом скрипты могут эти обертки держать живыми очень долго, наприм...
Arioch The
16
Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
37
Я тут пытаюсь переработать архитектуру подсистемы памяти ядра во что-то осмысленное. Есть pmm, который создает набор range’ей(пока что только для ядра, потом для юзерспейса), ...
Evg Resh
9
комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
Вот еще криповенькая штука. uMain.pas(517,3) Warning: Case statement does not handle all possible cases И ЧО? 😂
Александр (Rouse_) Багель
20
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
коллеги, а есть простой способ определить, что программу из под Delphi запускают?
Михаил
10
М-да. Почему бы просто со stringlist не работать?
Michael Longneck
23
.model small .stack 100h .data a db 'Hello, World!', '$' ; исходная строка b db 20 dup(?) ; строка b с запасом на максимальную длину .code main: ...
Алексей -man
3
Карта сайта