Главная страница
    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.042 c
15-1167157704
Kolan
2006-12-26 21:28
2007.01.21
Заствки между урвнями Call of Duty


2-1167725424
rolex
2007-01-02 11:10
2007.01.21
Как получить дискрипшн файла?


2-1167688184
-John-Doe-
2007-01-02 00:49
2007.01.21
Узнать что за ошибка по ее номеру (сетевые ошибки)


15-1167746350
ProgRAMmer Dimonych
2007-01-02 16:59
2007.01.21
Смотрю на задачу, как баран на новые ворота...


2-1167857415
Ламер 2.Х
2007-01-03 23:50
2007.01.21
Indy





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