Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.08.06;
Скачать: CL | DM;

Вниз

Хочу покаяться за то, что наговорил про генераторы в триггерах   Найти похожие ветки 

 
kaif ©   (2006-07-16 20:28) [0]

Как-то месяц назад я заявил, что юзать генераторы в триггерах IB - плохая традиция, так как это не позволяет найти только что вставленную запись (информация внутри триггера во внешний мир не проникает).
Вполне разумное предложение использовать в триггере проверку на NULL

 IF (NEW.ID IS NULL) THEN
  NEW.ID = GEN_ID(MyGenerator, 1);

я отверг, так как это не решало проблему.

Так получилось потому что я уже давно не использовал средства разработки типа IBExpress, а работал в основном в своей специализированной среде, где эти вопросы решались системой и несколько иначе.
Сейчас я пишу одну базу данных с нуля, используя IBExpert и я заметил, что если в IBExpert делаешь ручное добавление записей в таблицы, то приходится еще параллельно потом не забывать модифицировать генераторы, чтобы при работе приложения не попасть в VIOLATION первичного ключа.

Оказалось, что использование генераторов в триггерах с условием проверки ключевого поля при вставке на NULL снимает эту проблему и значительно упрощает процесс разработки базы, так как позволяет просто забыть о генераторах, даже если работаешь не из своего приложения, а просто "руками" в IBExpert.

Так что каюсь и беру свои слова назад.

Я вижу, что все же Имеет смысл использовать присвоение в триггерах BEFORE INSERT IB.

Разумеется, это не решает проблему нахождения вставленной записи, но зато решает другую проблему - герантированную модификацию генератора, не зависящую от способа вставки записи - из приложения или "руками" в IBExpert.

Как IBExpert находит вставленные записи - для меня загадка, если честно. Либо он прощучивает уникальные альтернативные ключи, либо опирается на содержимое всех полей. Не знаю.


 
DrPass ©   (2006-07-16 21:17) [1]

Господь прощает твои грехи, сын мой


 
unknown ©   (2006-07-17 00:12) [2]

Аминь.


 
Суслик ©   (2006-07-17 03:20) [3]

новичек ты наш :)


 
Desdechado ©   (2006-07-17 10:56) [4]

> имеет смысл использовать
Это и называется "бизнес-логика на сервере"
:)



Страницы: 1 вся ветка

Текущий архив: 2006.08.06;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.042 c
2-1153299112
Crazy monkey
2006-07-19 12:51
2006.08.06
Учет пользователей


2-1153396795
RobinBad
2006-07-20 15:59
2006.08.06
Чтение из файла по строкам


2-1152725374
Антибайт
2006-07-12 21:29
2006.08.06
Нарисовать кнопку внутри Edit, как у The Bat!.


15-1152079517
Prohodil Mimo
2006-07-05 10:05
2006.08.06
Кто-нибудь продавал программы через SoftKey?


4-1145268720
DVM
2006-04-17 14:12
2006.08.06
Как наиболее быстро и без задержек проверить доступность диска?