Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2003.01.02;
Скачать: [xml.tar.bz2];

Вниз

Что-то вроде триггера для 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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.56 MB
Время: 0.021 c
1-1795
Фил
2002-12-18 00:08
2003.01.02
Атрибуты файла


4-1934
ctapik-net
2002-11-14 18:39
2003.01.02
WM_QUERYENDSESSION - shutdown or reboot?


1-1770
Z-man7777
2002-12-20 09:45
2003.01.02
ini-файлы


14-1891
Agent Smith
2002-12-11 14:38
2003.01.02
С днем рождения, MBo!


14-1877
AL2002
2002-12-12 14:48
2003.01.02
Spider-man2 хочет TNL-capable 3D card





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский