Модераторы: Poseidon, Snowy, bems, MetalFan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Структура базы данных, Долго обрабатывается 
:(
    Опции темы
Barmaley
Дата 15.8.2003, 18:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Есть таблица CompSeller , содержащая данные, подразделенные на категории, т. е
имеются поля Name, Category и т.д.
Есть также таблица Category , содержащая описание категорий, т.е имеется поле Name, соответствующее полю Category в предыдущей таблице и куча других полей.

Есть дерево ElTree1 в него нужно расписать данные по категориям.

Я сделал так:

Код

 ElTree1.Items.Clear;
 Query1.Close;
 Query1.SQL.Clear;
 Query1.SQL.Add('select name from Category');
 Query1.Open;
 Query1.First;
 While not Query1.Eof do Begin
   s:=Query1.FieldByName('Name').Text;
   ti:= ElTree1.Items.Add(nil, s);
   Query2.SQL.Clear;
   Query2.SQL.Add('select Name,SellPrice,SellPrice,Comment,id from CompSeller where Category = "'+s+'"');
   Query2.Open;
   Query2.First;
   While not Query2.Eof do Begin
     tich:= ElTree1.Items.AddChild(ti, Query2.FieldByName('Name').Text);
     Query2.Next;
   End;
   Query2.Close;
   Query1.Next;
 Query1.Close;



работает непростительно долго. Подскажите пожалуйста, как можно сделать?

PM MAIL   Вверх
Vit
Дата 15.8.2003, 18:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


Профиль
Группа: Экс. модератор
Сообщений: 10964
Регистрация: 25.3.2002
Где: Chicago

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



Дык определите какая операция долго работатает, её и будем оптимизировать, я вижу не менее 4х строк которые могут притормаживать, но не буду давать решение для каждого случая...


--------------------
With the best wishes, Vit
I have done so much with so little for so long that I am now qualified to do anything with nothing
Самый большой Delphi FAQ на русском языке здесь: www.drkb.ru
PM MAIL WWW ICQ   Вверх
Barmaley
Дата 15.8.2003, 18:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Какие строки?
PM MAIL   Вверх
Vit
Дата 15.8.2003, 20:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


Профиль
Группа: Экс. модератор
Сообщений: 10964
Регистрация: 25.3.2002
Где: Chicago

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



Именно это я и спрашиваю - какие именно строки у вас тормозят


--------------------
With the best wishes, Vit
I have done so much with so little for so long that I am now qualified to do anything with nothing
Самый большой Delphi FAQ на русском языке здесь: www.drkb.ru
PM MAIL WWW ICQ   Вверх
Barmaley
Дата 16.8.2003, 10:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Я убрал некоторые строки и оставил только:
Код

Query1.Close;
Query1.SQL.Clear;
Query1.SQL.Add('select name from Category');
Query1.Open;
Query1.First;
While not Query1.Eof do Begin
  Query2.SQL.Clear;
  Query2.SQL.Add('select Name,SellPrice,SellPrice,Comment,id from CompSeller where Category = "'+Query1.FieldByName('Name').Text+'"');
  Query2.Open;
  Query2.First;
  While not Query2.Eof do Begin
    Query2.Next;
  End;
  Query2.Close;
  Query1.Next;
Query1.Close;

Таблица CompSeller имеет всего около 300 записей, но этот код обрабатывается около 3-х секунд.
Правда комп у меня не очень - Celeron 333 (работать можно), но мне кажется даже для него это очень долго.


PM MAIL   Вверх
Vit
Дата 16.8.2003, 14:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


Профиль
Группа: Экс. модератор
Сообщений: 10964
Регистрация: 25.3.2002
Где: Chicago

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



Неужели надо разжёвывать всё?

Ставь между операторами проверку времени, вычисляй время выполнения каждой строки, суммируй всё это, по окончанию кода - выводи на ъкран сколько какая строка кода заняла времени...


--------------------
With the best wishes, Vit
I have done so much with so little for so long that I am now qualified to do anything with nothing
Самый большой Delphi FAQ на русском языке здесь: www.drkb.ru
PM MAIL WWW ICQ   Вверх
Medved
Дата 16.8.2003, 22:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 7209
Регистрация: 15.9.2002
Где: Kazakhstan, Astan a

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



Есть специальные компоненты, которые делают то, чего выхотите добиться. В EhLib это точно есть. Может есть смысл воспользоваться ими?


--------------------
http://extreme.sport-express.ru/
...и неважно сколько падал, важно сколько ты вставал...
PM MAIL WWW ICQ Skype GTalk   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Общие вопросы"
SnowyMetalFan
bemsPoseidon
Rrader

Запрещается!

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

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

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


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, MetalFan, bems, Poseidon, Rrader.

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


 




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


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

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