Главная страница
    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.039 c
2-1167232199
Darvin
2006-12-27 18:09
2007.01.21
Передача сообщений приложению


9-1142551010
KiberKot
2006-03-17 02:16
2007.01.21
Поделитесь опытом


15-1167650853
zayatz
2007-01-01 14:27
2007.01.21
Отказ от празднования нового года


11-1143901726
BMouradov
2006-04-01 18:28
2007.01.21
Не могу изменить направление шрифта дважды


4-1157114323
Серге И
2006-09-01 16:38
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
Английский Французский Немецкий Итальянский Португальский Русский Испанский