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

Вниз

Можно ли выбрать в таблице записи у которых какое-либо поле NULL?   Найти похожие ветки 

 
Sirus ©   (2004-02-21 08:06) [0]

Привет Мастера...
Есть такая проблемка: Нужно выбрать из таблицы все записи в которых значение какого-либо поля NULL???


 
ЮЮ ©   (2004-02-21 08:12) [1]

WHERE (SomeField IS NULL)
и, наоборот,
WHERE ТЩЕ (SomeField IS NULL)


 
ЮЮ ©   (2004-02-21 08:13) [2]

ТЩЕ это NOT


 
Sirus ©   (2004-02-21 08:16) [3]

сформулируем вопрос по другому...
нужно выбрать список столбцов таблицы и их типы...
(потом уже можно будет сгенерить SQL)


 
ЮЮ ©   (2004-02-21 08:32) [4]

Для (SomeField IS NULL) знать тип поля не обязательно. А названия полей можно получить через
TIBDatabase.GetFieldNames(const TableName: string; List: TStrings); (или подобного метода используемого Connection-а, если это не TIBDatabase).

А типы можно извлечь или из системных таблиц или даже твоим запросом
SELECT * FROM Table WHERE
 (f1 IS NULL) or (f2 IS NULL) or ...
DataSet хоть и будет пуст, но его FieldDefs будут соответствовать таблице


 
Sirus ©   (2004-02-21 08:40) [5]

Дело в том что мне нужно при генерировании SQL запроса знать типы полей, чтобы добавить в SQL только NUMERIC поля...


 
ЮЮ ©   (2004-02-21 08:55) [6]

1) получаешь список полей ч/з GetFieldNames
2) формируешь запрос
 SELECT * FROM Table WHERE
(f1 IS NULL) AND (f2 IS NULL) AND ...
который быстро выполнится и не вернёт ни одной записи (т.к. Primary Key Field(S) <> NULL)
3) Анализируя FieldDefs формируешь нужный запрос
 SELECT * FROM Table WHERE
(NumericField1 IS NULL) OR (NumericField2 IS NULL) OR ...


 
P.N.P. ©   (2004-02-22 00:02) [7]

если заранее имя таблицы неизвестно,
то поля можно получить так

select f.rdb$field_name as
FN,f.rdb$null_flag as
N,fs.rdb$character_length as L,
f.rdb$description as FD,
t.rdb$type_name as T
from rdb$relation_fields f
left join rdb$fields fs on fs.rdb$field_name = f.rdb$field_source
left join rdb$types t on fs.rdb$field_type = t.rdb$type and (t.rdb$field_name= "RDB$FIELD_TYPE")
where f.rdb$relation_name="MyTableName"
order by f.rdb$field_position



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

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

Наверх




Память: 0.48 MB
Время: 0.039 c
7-1072523902
Nick_Omsk
2003-12-27 14:18
2004.03.28
Двунаправленная связь с компьютером


14-1078237109
Yakshe
2004-03-02 17:18
2004.03.28
Где взять баннер этого сайта?


3-1077370184
Nous Mellon
2004-02-21 16:29
2004.03.28
Сортировка и ADO


1-1078410757
Max
2004-03-04 17:32
2004.03.28
Добавление объекта в TComboBox


1-1078909890
MadGhost
2004-03-10 12:11
2004.03.28
как в функцию передать переменную по ссылке?