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

Вниз

Что-то вроде триггера для dbf   Найти похожие ветки 

 
sers   (2002-12-11 13:29) [0]

Есть чужая программа - работает с dbf, исходников нет. В ее dbf-ке я создал еще одно поле - текстовое. Смысл следующий - необходимо чтобы при вставке каждой записи в эту таблицу в мое поле проставлялся текущий пользователь, то есть тот логин под которым пользователь вошел в Windows.

Можно ли в чужой dbf-ке отловить момент вставки новой записи и соответственно updat-ить необходимую запись ?

Если нельзя выцепить запись - можно конечно сделать так:

update table set author=CurrentUser where author=""

Но как поймать момент вставки записи ?


 
Johnmen ©   (2002-12-11 13:58) [1]

> Но как поймать момент вставки записи ?

А кто, по-твоему, должен ловить ? Подумай над этим...


 
sers   (2002-12-11 16:19) [2]

Как кто. Моя прога. Вторая.

Например можно по таймеру отслеживать размер файла и если он увеличился запись вставлена. Хотя записи могут кэшироваться и это дело не пойдет.

Похоже что ничего тут не поделаешь


 
Digitman ©   (2002-12-11 16:37) [3]


> sers


Есть еще такое понятие как "транзакция". И если эта самая "чужая прога без исходников" хоть сколь-либо расчитана на многопользовательский режим доступа к базе на файл-сервере, она должна поддерживать хоть какой-то механизм транзакций.

В этой связи основным моментом является то, что при использовании транзакционного механизма запись считается успешно вставленной только в том случае, если транзакция выполнена успешно и подтверждена клиентом. В противном случае физически добавленная запись в контексте стартованной транзакции будет помечена как удаленная, если транзакция была откачена в результате каких-то коллизий в бизнес-логике. Иными словами, даже если тебе каким-то способом удастся реализовать триггер, то достоверность его срабатывания будет весьма сомнительной из-за необходимости еще и отслеживать каким-то образом результаты ВСЕХ выполнившихся успешно/неуспешно транзакций



 
dimis   (2002-12-11 17:12) [4]


> Digitman © (11.12.02 16:37)

c каких это пор в Paradoxе появились транзакции?

> sers
IMHO
вариантов два .
либо переписать программу
либо экспортировать таблички в другую СУБД ,где есть тригеры(например InterBase)
если программа написана нормально, то проблем возникнуть не должно


 
Roki   (2002-12-11 17:23) [5]

dimis прав - переписать прогу самый лучший выход. Разберись со структурой БД и впред!


 
Digitman ©   (2002-12-11 17:30) [6]

>dimis

С каких пор я упоминал при произнесении слова "транзакция" слово "Paradox" ?

Если уж на то пошло, то т/а в в этом случае "эмулируется" объетом BDE.TDatabase на базе *.lck- структур, создаваемых тем же Парадоксом



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

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

Наверх




Память: 0.48 MB
Время: 0.006 c
4-1928
Dpoxa
2002-11-16 21:59
2003.01.02
Как мне сменить кодировку в моем почтовой программе ?


1-1776
Aldokhin_Alex
2002-12-20 10:57
2003.01.02
Нужен алгоритм свертки


3-1755
LynxSS
2002-12-11 16:39
2003.01.02
Можно ли SQL-м соединить такие 2 таблицы.


14-1912
Almaren
2002-12-14 14:35
2003.01.02
Как узнать содержание активной записи в БД?


1-1787
smok_er
2002-12-20 12:27
2003.01.02
ReadLn и перемещение к началу файла