Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Delphi и запросы из Accesss, Помогите плиз 
:(
    Опции темы
SVN
Дата 29.5.2007, 10:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 16.5.2007

Репутация: нет
Всего: нет



Народ помогите плиз.
Есть БД в Access со связанами таблицами и  запросами, к delphi подключены таблицы через ADOTable, DataSource и DBGRid.
Как сделать чтоб запрос находящийся в БД запускался из Deiphi?
Я делаю через ADOQuerry, настраиваю его, указываю таблицу и пишу в нем код запроса, ставлю кнопку на форму и указываю в ней ADOQuerry.
Прикомпилировании ошибок нет, но при нажатии на кнопку ничего не происходит.
Нужно чтоб в другом DBGrid показывался результат запроса.

Подскажите что я не так сделал, если можно с простеньким кодом для примера кодом кнопки чтоб запрос работал.
PM MAIL   Вверх
Rodman
Дата 29.5.2007, 10:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 22
Всего: 122



Код

ADOQuerry.Open;


сделал?

если не подойдет - выложи код
PM MAIL WWW Skype GTalk YIM MSN   Вверх
Sansa
Дата 30.5.2007, 12:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 173
Регистрация: 18.10.2006
Где: Королев

Репутация: 2
Всего: 6



Насколько я помню, запросы, находящиеся в DB Access для Delphi выглядят как таблицы. Используй ADOTable, и в качестве TableName укажи нужный запрос
--------------------
- Здравствуйте, я Ваш патологоанатом
PM MAIL ICQ   Вверх
Foley
Дата 31.5.2007, 16:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Фсемба Яцца
*


Профиль
Группа: Участник
Сообщений: 235
Регистрация: 31.1.2006
Где: Россия, Арх.обл

Репутация: нет
Всего: 7



У кого-нить есть готовая прога, делающая выборку по дате в MS Access через ADO? 
если есть прикрепите в аттач, очень надо, читал разные материалы, но почему то не получилось сделать

Или если мона то маленькую прогу с выборкой по дате ПЛИЗ

PM MAIL ICQ   Вверх
TaNK
Дата 31.5.2007, 16:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 669
Регистрация: 29.10.2006
Где: Краснодар

Репутация: нет
Всего: 1



Цитата(Foley @ 31.5.2007,  16:15)
У кого-нить есть готовая прога, делающая выборку по дате в MS Access через ADO? 
если есть прикрепите в аттач, очень надо, читал разные материалы, но почему то не получилось сделать

Или если мона то маленькую прогу с выборкой по дате ПЛИЗ

Есть небольшая, но только на плюсах написанная...(С++) подойдет?

Это сообщение отредактировал(а) TaNK - 31.5.2007, 16:48


--------------------

Oracle 11.2.0.3.0
FireBird 1.0-2.5


PM MAIL ICQ   Вверх
Rodman
Дата 31.5.2007, 17:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 22
Всего: 122



Foley, не чуди... выложи то что у тебя не получается, а я поправлю...
PM MAIL WWW Skype GTalk YIM MSN   Вверх
Foley
Дата 1.6.2007, 11:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Фсемба Яцца
*


Профиль
Группа: Участник
Сообщений: 235
Регистрация: 31.1.2006
Где: Россия, Арх.обл

Репутация: нет
Всего: 7



Вот код:
Код

ADOQuery1.Active:=false;
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM Prazd WHERE  Data="'+DateToStr(DateTimePicker1.Date)+'"');
ADOQuery1.Active:=True;  


Такой код тоже не работает:

Код

ADOQuery1.Active:=false;
with ADOQuery1 do begin
    SQL.Clear;
    SQL.ADD('select * from Prazd where Date < :MyDate');
    Parameters.ParamByName('MyDate').Value:=DateToStr(DateTimePicker1.Date);
    Open;
end;


А также:
Код

ADOQuery1.Active:=false;
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM mytable WHERE  return_date BETWEEN :DateBeg AND :DateEnd')
ADOQuery1.Parameters.ParseSQL(ADOQuery1.SQL.Text, True);
ADOQuery1.Parameters.ParamByName('DateBeg').Value:=FormatDateTime('dd.mm.yyyy',StrToDate(MaskEdit1.Text))+' 00:00:00';
ADOQuery1.Parameters.ParamByName('DateEnd').Value:=FormatDateTime('dd.mm.yyyy',StrToDate(MaskEdit1.Text))+' 23:59:59';
ADOQuery1.Active:=true;


Также пробовал:
Код

ADOQuery1.SQL.Add('SELECT * FROM Prazd WHERE  Data=#'+DateToStr(DateTimePicker1.Date)+'#');

Где-то читал что это должно помочь, но почему-то не получилось... smile

Добавлено через 1 минуту и 22 секунды
TaNK, давай на си, там все равно структура кода очень похожа... тем более SQL...
PM MAIL ICQ   Вверх
Rodman
Дата 1.6.2007, 11:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 22
Всего: 122



Foley, в место 
Код

ADOQuery1.Active:=True; 


делай 
Код

ADOQuery1.Open; 

обычно помагает!
PM MAIL WWW Skype GTalk YIM MSN   Вверх
Rodman
Дата 1.6.2007, 11:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 22
Всего: 122



Я бы сделал так:
Первый
Код

ADOQuery1.Close;
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM Prazd WHERE  Data=:Prm1');
ADOQuery1.Parameters.ParamByName('Prm1').Value:=DateToStr(DateTimePicker1.Date);
ADOQuery1.Open;  


Второе
Код

with ADOQuery1 do begin
    Close;
    SQL.Clear;
    SQL.ADD('select * from Prazd where Date < :MyDate');
    Parameters.ParamByName('MyDate').Value:=DateToStr(DateTimePicker1.Date);
    Open;
end;


Третье
Код

ADOQuery1.Close;
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM mytable WHERE  return_date BETWEEN :DateBeg AND :DateEnd')
ADOQuery1.Parameters.ParamByName('DateBeg').Value:=FormatDateTime('dd.mm.yyyy',StrToDate(MaskEdit1.Text))+' 00:00:00';
ADOQuery1.Parameters.ParamByName('DateEnd').Value:=FormatDateTime('dd.mm.yyyy',StrToDate(MaskEdit1.Text))+' 23:59:59';
ADOQuery1.Parameters.ParseSQL(ADOQuery1.SQL.Text, True);
ADOQuery1.Open;


Последнее - первый раз слышу, но утверждаться не берусь!
PM MAIL WWW Skype GTalk YIM MSN   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.0818 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.