Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 09.06.2011, 23:17
Аватар для ALexandr555
ALexandr555 ALexandr555 вне форума
Специалист
 
Регистрация: 09.10.2010
Адрес: Тольятти
Сообщения: 803
Версия Delphi: Delphi 7
Репутация: 2064
По умолчанию Результат поиска в БД

Нужно узнать результат поиска, но не визуально посмотрев на BDGrid
Код:
  Query.Close;
 Query.SQL.Clear;
 Query.SQL.Add('Select * from ZZZ where XXX LIKE "'+YYY+'"');
после этого поиска нужно как то вывести не найден результат либо какой результат первый в поле XXX .

Последний раз редактировалось ALexandr555, 09.06.2011 в 23:20.
Ответить с цитированием
  #2  
Старый 09.06.2011, 23:40
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

RecordCount не пробовал?
Ну или EOF в крайнем случае?

И вообще, здесь хоть кто-нить в документацию заглядывает???
Ответить с цитированием
  #3  
Старый 10.06.2011, 00:02
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Запросом вроде Rowcount можно спросить.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
  #4  
Старый 10.06.2011, 00:13
Аватар для ALexandr555
ALexandr555 ALexandr555 вне форума
Специалист
 
Регистрация: 09.10.2010
Адрес: Тольятти
Сообщения: 803
Версия Delphi: Delphi 7
Репутация: 2064
По умолчанию

Код:
if Query.RecordCount <> 0 then
  begin
   ShowMessage(рузультат запись из поля XXX);
  end else
  begin
   ShowMessage('Нет записей удовлетворяющих поиску');
  end;

определить понял как, как тогда вывести вот результат
Ответить с цитированием
  #5  
Старый 10.06.2011, 01:28
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ручками, ручками.
собирай по полям в строку и выводи. Или сделай отдельную формочку с DBGrid для вывода результатов поиска.
Ответить с цитированием
  #6  
Старый 10.06.2011, 02:01
Аватар для ALexandr555
ALexandr555 ALexandr555 вне форума
Специалист
 
Регистрация: 09.10.2010
Адрес: Тольятти
Сообщения: 803
Версия Delphi: Delphi 7
Репутация: 2064
По умолчанию

только начал работу с этим и не знаю что использовать чтобы с поля строчку то взять,
еще при добавлении Query.SQL.Add('INSERT INTO bdbot (ZZZ, GGG,FFF) VALUES ('+XXX+','+YYY+','+IntToStr(idbd)+')');
ругается на XXX? параметр не имеет значения по умолчанию
нашел в поиске только Если возможно, указывайте значения по умолчанию последними в списке аргументов
Ответить с цитированием
  #7  
Старый 10.06.2011, 09:02
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от ALexandr555
только начал работу с этим и не знаю что использовать чтобы с поля строчку то взять,


Код:
FieldbyName('name').AsString;

Цитата:
Сообщение от ALexandr555
еще при добавлении Query.SQL.Add('INSERT INTO bdbot (ZZZ, GGG,FFF) VALUES ('+XXX+','+YYY+','+IntToStr(idbd)+')');
ругается на XXX? параметр не имеет значения по умолчанию
нашел в поиске только Если возможно, указывайте значения по умолчанию последними в списке аргументов

да нет тут у тебя параметров...

ЗЫ. Ну найди хоть какую-нить книжку и пролистай ее. 75% вопросов сразу отпадет.
Ответить с цитированием
  #8  
Старый 10.06.2011, 09:18
Аватар для ALexandr555
ALexandr555 ALexandr555 вне форума
Специалист
 
Регистрация: 09.10.2010
Адрес: Тольятти
Сообщения: 803
Версия Delphi: Delphi 7
Репутация: 2064
По умолчанию

http://usingvb.narod.ru/pages/state/state/sql.htmс самого начала нашел вот это но тут считай только по запросам, от туда и разбираю, дома в книге по D7 тоже только запросы и то меньше чем на сайте, ну и исходник смотрю.

Согласен что нет пораметров но ругается

Код:
FieldbyName('name').AsString;
то что хотел спасибо

к примеру если даже указываю не переменную, а 'GFGJ'
Код:
Query.SQL.Add('INSERT INTO bdbot (FFF, ZZZ,XXX) VALUES (GFGJ,'+YYY+','+IntToStr(idbd)+')');

то так же выдает что "Параметр GFGJ не имеет значения по умолчанию."

Последний раз редактировалось ALexandr555, 10.06.2011 в 09:49.
Ответить с цитированием
  #9  
Старый 10.06.2011, 10:02
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Там есть метод "AddParam". И еще, если поле FFF varchar, то GFGJ надо в кавычки заключить.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию

Последний раз редактировалось M.A.D.M.A.N., 10.06.2011 в 10:04.
Ответить с цитированием
  #10  
Старый 10.06.2011, 10:46
Аватар для ALexandr555
ALexandr555 ALexandr555 вне форума
Специалист
 
Регистрация: 09.10.2010
Адрес: Тольятти
Сообщения: 803
Версия Delphi: Delphi 7
Репутация: 2064
По умолчанию

Код:
Query.SQL.Add('INSERT INTO bdbot (ZZZ, GGG,FFF) VALUES ('+XXX+','+YYY+','+IntToStr(idbd)+')');
Query.Parameters.AddParameter;
Query.Open;

Не правильно определен объект параметр предоставлены не согласованные или не полные сведенья.

есть такой метод...
Ответить с цитированием
  #11  
Старый 10.06.2011, 11:04
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Я тебя боюсь, понял?!
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
  #12  
Старый 10.06.2011, 11:11
Аватар для ALexandr555
ALexandr555 ALexandr555 вне форума
Специалист
 
Регистрация: 09.10.2010
Адрес: Тольятти
Сообщения: 803
Версия Delphi: Delphi 7
Репутация: 2064
По умолчанию

что мне пытаться втолковать намеками на метод если я не работал с этим ни разу?)
вот от сюда смотрю http://usingvb.narod.ru/pages/state/state/sql.htm
Цитата:
NSERT INTO Orders (ID, Name, Email, Order) VALUES (12, 'Вася Пупкин', 'vasya@pupkin.ru', 'Pentium II 450 MHz');

Добавляется новая запись, в которой полям ID, Name, Email, Order соответствуют значения 12, 'Вася Пупкин', 'vasya@pupkin.ru', 'Pentium II 450 MHz'.
делаю по аналогии и не выходит, вот и пытаюсь понять в чем дело )
Ответить с цитированием
  #13  
Старый 10.06.2011, 12:16
Аватар для ALexandr555
ALexandr555 ALexandr555 вне форума
Специалист
 
Регистрация: 09.10.2010
Адрес: Тольятти
Сообщения: 803
Версия Delphi: Delphi 7
Репутация: 2064
По умолчанию

вобщем после поисков нашел где написано про присвоение параметров
http://forum.vingrad.ru/forum/topic-2505.html
и вышло у меня нечто такое
Код:
Query.SQL.text:='INSERT INTO bdbot (ZZZ, GGG,FFF) VALUES (par1,'+YYY+','+IntToStr(idbd)+')';
     Query.Parameters.ParseSQL(Query.SQL.Text, True);
     Query.Parameters.ParamByName('par1').Value:=XXX;
     Query.open;
ну и ошибка Parameter 'par1' was not found,
хотя в той темке говорилось что
Код:
Query.Parameters.ParseSQL(Query.SQL.Text, True);
избаляет от этой ошибки
Ответить с цитированием
  #14  
Старый 10.06.2011, 12:23
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

параметры в sql-запросе обычно оформляются через двоеточие, т.е. так:
Код:
Query.SQL.text:='INSERT INTO bdbot (ZZZ, GGG,FFF) VALUES (:par1,'+YYY+','+IntToStr(idbd)+')';
а вот обращение к параметру уже без двоеточия и вы уже это нашли:
Код:
Query.Parameters.ParamByName('par1').Value:=XXX;
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #15  
Старый 10.06.2011, 13:18
Аватар для ALexandr555
ALexandr555 ALexandr555 вне форума
Специалист
 
Регистрация: 09.10.2010
Адрес: Тольятти
Сообщения: 803
Версия Delphi: Delphi 7
Репутация: 2064
По умолчанию

Код:
Query.SQL.text:='INSERT INTO bdbot (ZZZ, GGG,FFF) VALUES (:par1,'+YYY+','+IntToStr(idbd)+')';
     Query.Parameters.ParseSQL(Query.SQL.Text, True);
     Query.Parameters.ParamByName('par1').Value:=XXX;
     Query.open;

Не одна так другая, "текущий поставщик не поддерживает возврат нескольких наборов записей в результате одной операции".

нашел что нужно заменить Query.open на Query.ExecSQL; в принципе работает, единственное из BDGrid пропадают записи, но проблемы нет по новой буду грузить.
Спасибо за помощь.

Последний раз редактировалось ALexandr555, 10.06.2011 в 13:30.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 08:41.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter