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

Вниз

Триггер не ловит Null вроде   Найти похожие ветки 

 
Vemer   (2004-01-03 17:24) [0]

Здравствуйте.
Есть таблица с двумя полями, POLE(Int) и Ctrl(SmallInt) и триггер Before Update типа:
IF (new.Pole <> old.Pole) then
new.ctrl = old.Ctrl + 1


То есть триггер отмечает в CTRL изменения POLE, но путем несложных экспериментов я установил, что триггер не ловит изменения с NULL и на NULL.
В принципе это можно победить, забивая в поле изначально какие-то значения.
Вопрос - можно ли это победить как-нибудь проще, по другому.


 
jack128   (2004-01-03 17:40) [1]

Тригер, то ловит, не ловит твое условие.
(null <> 10) - это false


 
Rad   (2004-01-03 20:35) [2]

Надо проверять new.Pole IS NULL


 
Vemer   (2004-01-03 23:37) [3]

Всем спасибо.
Триггер слишком громоздкий получаеться (проверка 3-х условий).
Поля текстовые, шифрованные, заполняються не напрямую поэтому просто сделал надпись "нет" когда нет значения.


 
Jack128   (2004-01-04 06:30) [4]


> просто сделал надпись "нет" когда нет значения
Не есть это хорошо. Вдруг нужно будет в базу слово "нет" запихнуть ;-)
А вообще в чем проблема, то?
Сложно вместо IF (new.Pole <> old.Pole) then
написать
if ((new.Pole is null and old.Pole is not null) or
(new.Pole is not null and old.Pole is null) or
(new.Pole <> old.Pole)) then


 
Vemer   (2004-01-04 15:10) [5]

Спасибо за пример, где-нибудь пригодиться (хотя проще будет поставить Default какой-нибудь).
Для 12 полей будет громоздко(IMHO), а запихивать "Нет" в телефоны и адреса навряд-ли придеться + с "нет" даже лучше смотриться. Хотя "громоздко" понятие тоже растяжимое.



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

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

Наверх




Память: 0.45 MB
Время: 0.008 c
7-93706
Talla2k
2003-11-12 01:01
2004.01.29
Com port


1-93537
Cardinal
2004-01-17 10:25
2004.01.29
Как закрыть консоль при отсутствии ошибок?


1-93521
_DM_
2004-01-18 10:27
2004.01.29
TWebBrouser


3-93338
NickNaz
2004-01-04 20:15
2004.01.29
отчет Quick Rep


8-93590
arcoant
2003-09-23 22:07
2004.01.29
OpenGL





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский