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

Вниз

Null в SQL и Delphi   Найти похожие ветки 

 
Kostafey ©   (2006-12-28 19:23) [0]

Доброго времени суток! Взгляните на этот код. В нем заполняются items для ComboBox.

   Active := false;
   CommandText := "select case when VOX.VOX_NAME is null then NULL else VOX.VOX_NAME end as Res from VOX";
   Active := true;
   ComboBox_VOX.Items.Clear;
   ComboBox_VOX.Items.Add(GlbVar.Vse_VOX);
   for i := 1 to RecordCount do begin
     if FieldValues["Res"] = NULL then
     begin
       next; continue;
     end;
     ComboBox_VOX.Items.Add(FieldValues["Res"]);
     next;
   end;
   ComboBox_VOX.ItemIndex := 1;

Код успешно работает. Но вот на какие мысли наталкивает его рассмотрение.

1) В SQL "is null" и "=null" не одно и то же, а в Delphi- пожалуста пишем if FieldValues["Res"] = NULL. Это правильно ?

2) Взгляните на вторую строчку кода. Казалось бы ничего не мешает написать просто "select VOX.VOX_NAME as Res from VOX" но нет же ошибка.
Так вот чем это может быть вызвано ?


 
Ega23 ©   (2006-12-28 19:29) [1]

Case в данном случае - бессмыслен.


 
Ega23 ©   (2006-12-28 19:31) [2]


> 1) В SQL "is null" и "=null" не одно и то же, а в Delphi-
>  пожалуста пишем if FieldValues["Res"] = NULL. Это правильно
> ?


В С (a==b) и (a=b) не одно и то же, а в Delphi- пожалуста пишем (a=b). Это правильно ?


 
Kostafey ©   (2006-12-28 19:40) [3]

> Case в данном случае - бессмыслен.

Ух, смотри-ка заработало! А что-ж у меня до этого не работало-то...? А что-ж я до этого там пил-то...? :)


> В С (a==b) и (a=b) не одно и то же, а в Delphi- пожалуста
> пишем (a=b). Это правильно ?

Хм. Просто я хочу сказать кто из них неправ? SQL (вкрнее стандарт ANSI SQL) или Delphi ?


 
Ega23 ©   (2006-12-28 19:47) [4]


> Хм. Просто я хочу сказать кто из них неправ? SQL (вкрнее
> стандарт ANSI SQL) или Delphi ?


Ты тёплое с мягким путаушь. В случае Delphi - это тип данных Variant


 
Kostafey ©   (2006-12-28 19:55) [5]

> Ты тёплое с мягким путаушь. В случае Delphi - это тип данных
> Variant

Да? Возможно мне пора бы вернуться к фундаментальной литературе на эту тему.
Хм. Кстати, мысль, но это уже во флуде. В любом случае спасибо.


 
DrPass ©   (2006-12-29 01:24) [6]


> Kostafey ©   (28.12.06 19:55) [5]

Да, не мешало бы :)
Null в SQL = "неопределенное значение"
Null в вариантных переменных Delphi = "пустое значение"


 
ЮЮ ©   (2006-12-29 03:55) [7]

Да и Дельфи лучче не сравнивать с Null и Unassigned, а использовать функции VarIsNull и VarIsEmpty, ибо случаются такие конфигурации, где прямое сравнение приводит е ошибкам преобразования. У меня дома такая конфигурация сложилась и я там отлавливаю такого типа ошибки, хотя на работе все происходит без ошибок.



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

Форум: "Начинающим";
Текущий архив: 2007.01.21;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.04 c
15-1167761848
vidiv
2007-01-02 21:17
2007.01.21
как сделать форму toolwindow всегда выше всех форм


2-1167742529
FIL-23
2007-01-02 15:55
2007.01.21
создание файлов


2-1168086965
Ламер 2.Х
2007-01-06 15:36
2007.01.21
Закрытие формы


11-1142160418
homm
2006-03-12 13:46
2007.01.21
Flat Controls


15-1167655682
_uw_
2007-01-01 15:48
2007.01.21
Не надо читать спам и тем более сюда постить





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