Главная страница
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.042 c
14-1074854262
Sergey_Masloff
2004-01-23 13:37
2004.03.28
надежная работа сервера delphi.mastak.ru


14-1077725322
copyr25
2004-02-25 19:08
2004.03.28
В СИЗО Ленинградской области заключенные объявили


1-1078474460
stainer
2004-03-05 11:14
2004.03.28
меню в стиле offce xp


14-1077900040
Giemgo
2004-02-27 19:40
2004.03.28
Пароль на USB


3-1077782258
Alex*
2004-02-26 10:57
2004.03.28
Как пользоваться командой DbiPackTable