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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 22.07.2011, 02:51
Metal Metal вне форума
Прохожий
 
Регистрация: 22.07.2011
Сообщения: 11
Версия Delphi: 7, XE
Репутация: 10
По умолчанию Как отобразить результат SQL-запроса не в DBGrid

Такой вопрос.

Скажем, посылаю я через ADOQuery запрос 'SHOW DATABASES'. Он мне возвращает список доступных баз, но вывести я его могу только в DBGrid через DataSources.

Единственное, что нашел хотя бы близко, это ADOQuery.Fields.Fields[index]. Но тут с увеличением индекса я просто двигаюсь вправо по ответу: в случае, скажем, с 'SHOW DATABASES', я могу только индекс 0 поставить, тогда он просто вернет мне название самой верхней базы.
Как получить доступ к остальным строкам ответа?

Работаю с MySQL через ADO с помощью ODBC.
Пишу в Delphi XE
Ответить с цитированием
  #2  
Старый 22.07.2011, 07:20
Аватар для 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
Репутация: выкл
По умолчанию

Код:
  DataSet.First;
  while not DataSet.EOF do
  begin
    ...
    mmo1.Lines.Add(DataSet.FieldByName['bla-bla-bla'].AsString);
    DataSet.Next;
  end;
  ...
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
  #3  
Старый 22.07.2011, 10:44
Аватар для Viajero
Viajero Viajero вне форума
Активный
 
Регистрация: 14.06.2011
Адрес: РБ
Сообщения: 214
Версия Delphi: Delphi 7 FB 2.5
Репутация: 5849
По умолчанию

Цитата:
Как получить доступ к остальным строкам ответа?
Датасет это же не массив. Прямой доступ к строкам как правило невозможен (В некоторых случаях если Dataset связан непосредственно с конкретной таблицей возможен, но в такой конфигурации
Цитата:
Работаю с MySQL через ADO с помощью ODBC
это исключено).
Сначала надо указатель (в ADO это курсор) установить на строку с помощью методов:
First (в начало),
Next(след. строка),
Prior(пред. строка)
Last (в конец)
Locate (найти строку по какому-л ключу)
Потом читать нужное поле методом Fieldbyname или через свойство Fields

Советую вам почитать что-нибудь, например это
Андрей Сорокин. Delphi - Разработка баз данных.
http://letitbit.net/download/b9f4b61...delp7.rar.html
__________________
- Товарищ прапорщик!!! Остановите поезд!!! - Поезд СТОЙ! РАЗ! ДВА!

Последний раз редактировалось Viajero, 22.07.2011 в 13:22.
Ответить с цитированием
  #4  
Старый 22.07.2011, 12:21
Metal Metal вне форума
Прохожий
 
Регистрация: 22.07.2011
Сообщения: 11
Версия Delphi: 7, XE
Репутация: 10
По умолчанию

Viajero

Спасибо тебе, добрый человек! Так объяснил, что и читать уже ничего не надо! Сотни нефти тебе!

M.A.D.M.A.N.

Не совсем то, что я спрашивал, но тож спасибо!
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter