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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 07.06.2012, 10:56
ins813 ins813 вне форума
Прохожий
 
Регистрация: 24.05.2012
Сообщения: 32
Репутация: 10
По умолчанию работа с ADO без DGRID

Здравствуйте, скажите пожалуйста, есть MSSQL-БД, ADOQueary. Как выгрузиться с помощью Queary в Excel ?
Код:
ADOQuery1.First;
 for i:= 1 to ADOQuery1.RecordCount -1 do
begin
 for j:= 1 to DBGrid1.Columns.Count do
sheet.cells[index,1]:=adoquery1.FieldByName('name').AsString;
inc(index);
ADOQuery1.Next;
 end;
Админ: двухдневный бан за отсутствие оформления кода.

Последний раз редактировалось Admin, 07.06.2012 в 11:00.
Ответить с цитированием
  #2  
Старый 07.06.2012, 11:28
Аватар для 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
Репутация: выкл
По умолчанию

Через OLE взаимодействие, как вариант. Тока АДО тут не причем уже.
Кстати, в Эксэль можно прямо результат запроса вываливать, онавтоматом табличку строит.
Ответить с цитированием
  #3  
Старый 07.06.2012, 11:32
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Я вашем коде вообще не понимаю, зачем там грид. Сразу читайте и пишите данные, примерно так:
Код:
for i:= 1 to ADOQuery1.RecordCount -1 
do begin
    sheet.cells[i,1]:=adoquery1.FieldByName('name').AsString; 
    AdoQuery1.Next;   
    end;
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #4  
Старый 12.06.2012, 21:36
Аватар для ALexandr555
ALexandr555 ALexandr555 вне форума
Специалист
 
Регистрация: 09.10.2010
Адрес: Тольятти
Сообщения: 803
Версия Delphi: Delphi 7
Репутация: 2064
По умолчанию

Цитата:
Сообщение от Страдалецъ
Я вашем коде вообще не понимаю, зачем там грид. Сразу читайте и пишите данные, примерно так:
Код:
for i:= 1 to ADOQuery1.RecordCount -1 
do begin
    sheet.cells[i,1]:=adoquery1.FieldByName('name').AsString; 
    AdoQuery1.Next;   
    end;
по моему без -1 в ADOQuery1.RecordCount -1 просто
Код:
for i:= 1 to ADOQuery1.RecordCount
или тогда
Код:
for i:= 0 to ADOQuery1.RecordCount-1
а то последнее не возьмет, или если запись одна то ничего не сделает
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter