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

Вниз

Кол-во записей в БАЗЕ INTERBASE   Найти похожие ветки 

 
Russko   (2004-12-27 10:21) [0]

Я выполняю запрос:
Query6.SQL.Clear;
Query6.SQL.Add("select * from main_base_svod where (gost_mat=""+gost+"")and(F_S=""+(first)+"")and(gost_prok=""+gost_pr+"") ");
Query6.OPen;
Затем смотрю Query6.RecordCount и он равен 0, хотя должен быть равен 9.
Проблема в (gost_mat=""+gost+""). Если gost пустая строка, то он всегда возвращает RecordCount=0
КАК ЭТО ИСПРАВИТЬ -ПОДСКАЖИТЕ ПОЖАЛУЙСТА


 
Russko   (2004-12-27 10:24) [1]

Да, переменная gost - string.
Чувствую, что идёт не совпадение типов ((


 
Sergey13 ©   (2004-12-27 10:30) [2]

Ну дык, если ты динамически составляешь запрос, то можно и прореагировать на "Если gost пустая строка". Или вообще выкинуть из запроса, или написать gost_mat is null - смотря что надо.


 
Russko   (2004-12-27 10:34) [3]

Мдя, так то оно так, но gost не всегда может быть пустым. Вопрос в том, какой тип для это переменной использовать, чтобы InterBase понимал: если переменная gost-пустая, то и надо искать где gost_mat - тоже пустая


 
Sergey13 ©   (2004-12-27 10:40) [4]

2[3] Russko   (27.12.04 10:34)
Ты определись - что такое "пустая". Пробел тоже кажется пустотой. Но это не так. Как и "".

>чтобы InterBase понимал:
Твоя задача - объяснить ему это.


 
Russko   (2004-12-27 10:45) [5]

)) Подскажи как можно это объяснить, каким образом записать, просто трудно переходить с локальной базы на сетевую ((
Пустая - значит ничего не заносилось ))
Тип поля gost_mat- varchar(30)


 
Sergey13 ©   (2004-12-27 10:47) [6]

gost_mat is null


 
Соловьев ©   (2004-12-27 10:48) [7]

Затем смотрю Query6.RecordCount и он равен 0, хотя должен быть равен 9.

Ну нужно сделать во-первых - QUery6.FetchAll;
Но это я бы сказал - барство. А для подсчета, юзать такой же запрос, но вместо полей count(*) и дергать такой запрос через IBSQL.

И откажысь ты от IBQeury - IBDataSet надо юзать.


 
Russko   (2004-12-27 10:58) [8]

2 Sergey13 ©
Да но переменная может быть и не пустой, я не могу в запросе просто вставить gost_mat is null


 
Sergey13 ©   (2004-12-27 11:02) [9]

2 [8] Russko   (27.12.04 10:58)
Перечитай [2]


 
Russko   (2004-12-27 11:09) [10]

а почему Paradox понимал, если строка пустая, то пустая !


 
DSKalugin ©   (2004-12-27 12:38) [11]

Если хочешь знать количество для этого есть другой немножко запрос.

Query6.SQL.Clear;
Query6.SQL.Add("select count(*) from main_base_svod where (gost_mat=""+gost+"")and(F_S=""+(first)+"")and(gost_prok=""+gost_pr+"") ");
Query6.OPen;



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

Форум: "Базы";
Текущий архив: 2005.01.30;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.46 MB
Время: 0.038 c
8-1098001082
Ralf
2004-10-17 12:18
2005.01.30
Сглаживание краёв


14-1105527640
Dimir
2005-01-12 14:00
2005.01.30
mdac typ.exe


14-1105344544
Delirium
2005-01-10 11:09
2005.01.30
ZIP-код


6-1100034718
able
2004-11-10 00:11
2005.01.30
TServerSocket число соединений


1-1106072728
Magic_STI
2005-01-18 21:25
2005.01.30
Неодинаковое время выполнения. Почему?





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