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

Вниз

Кол-во записей в БАЗЕ 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;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.027 c
1-1106129382
WondeRu
2005-01-19 13:09
2005.01.30
Отключить стандартную прорисовку потомка от TPanel


1-1106041657
hgd
2005-01-18 12:47
2005.01.30
Ошибка на CoInitialize;


1-1106125969
Ega23
2005-01-19 12:12
2005.01.30
Выполнится ли Beep ?


3-1104231699
Dysan
2004-12-28 14:01
2005.01.30
не работает запрос при использовании параметров в ADO


14-1105367916
Kerk
2005-01-10 17:38
2005.01.30
Переведите пожалуйста