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

Всем привет, собсно вот такой вопрос созрел: Update/delete - это очень

опасные функции, потому что идёт потеря данных. Собсно как делать к примеру максимально безопасный update?

К примеру я делаю такой запрос:
update customers set money = 0
where [my condition]
Логично, что прежде чем что-то апдейтить, я должен удостовериться, что мой кондишн выдаёт мне те результаты, которые мне нужны. То есть заранее важно бы сделать select ... from customers where [my condition].

Ок, хорошо, кондишн верный, начал писать свой апдейт, и тут меня отвлекли, я вернулся, забыл и прописал update customers set money = 0, а кондишн забыл добавить, бац. Бизнесу полный ****.
Собственно вопрос такой - какие паттерны есть для безопасного апдейта/делета таблицы?

6 ответов

14 просмотров

Бэкапы делать.

Ilya Anfimov
Бэкапы делать.

Это по умолчанию долго быть :)

Begin tran Update Rollback Tran

Ну кстати многие используют для delete подход когда у строки есть условный статус 0, что значит не удалена и статус 1 что значит удалена и соответственно во всех вью всегда стоит проверка на 0, и все процедуры удаления по факту изменяют статус, даже если пользователь из интерфейса "удалил" запись, а потом прибежал со словами караул как всё вернуть, ты просто в базе изменишь статус нужной записи.

Ну гопа как обычно

Max Rudnev
Ну гопа как обычно

Нормальное решение кстати. Ну или включать опцию set implicit_transactions on. Тогда begin tran автомаГически при любом апдейте будет срабатывать.

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Мужики. привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных элементов...
Kraszx
2
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Всем привет! Кто пользуется DevExpress, подскажите пожалуйста, реализован ли в TcxGrid в новых версиях поиск по датам как в Экселе (ну т.е. не просто список чекбоксов со значе...
A Z
4
Карта сайта