Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.05.23;
Скачать: [xml.tar.bz2];

Вниз

Проблема скорости в базе данных   Найти похожие ветки 

 
Sirus   (2002-04-25 06:41) [0]

Привет Мастерам... Есть тут проблемка...
База: InterBase 5.5
использую DataModule. Открываю Database затем создаю запрос Query, а потом данные запроса через DataSource на форму в DBGrid... Все работает, только работает очень медленно. Особенно если в процессе работы программы запрос обновляется. В таблице около 500000 записей. Таких таблиц около 10. При формировании запроса на каждую таблицу уходит около 12 секунд. Может есть другой способ работать с таблицами создавая запросы, более быстрый... подскажите, а то при сохранении программа "зависает" на минуту и более...


 
Alexandr   (2002-04-25 07:30) [1]

Это к доктору

надо просто запрос правильно написать, индексы к таблицам создать правильные.

Ты бы привел тута че-за запрос, че-за таблицы, мы б тебе запрос томогли подкрутить.


 
Sirus   (2002-04-25 13:05) [2]

Запрос достаточно простой... тут по моему даже нечего крутить...
select * from SUBS_DATA
where CHANGED<>"3"
order by SUBS_CODE

вот и весь запрос... тут во всех таблицах используются такие запросы... сложных запросов не делаю..
А сохранение
DataModule.Query.Post


 
Alexandr   (2002-04-25 13:11) [3]

при чем тут сохранение?

1) индекс по changed и subs_code есть?
2) сколько записей в таблице?


 
Sirus   (2002-04-26 14:13) [4]

Записей в таблице около 500 000,
а индексов в таблицах нету... нигде...
Если можно, то дайте плииз инфу по индексам, а то чет не пойму каким боком они к этим таблицам подходят...


 
Johnmen   (2002-04-26 14:18) [5]

Проще всего почитать книжки по поводу индексов и определиться, какие надо скастромить для конкретных таблиц, после чего и осуществить это... :)


 
Desdechado   (2002-04-28 15:48) [6]

По индексам поиск (where) и сортировка (order by) на порядки быстрее проходят


 
arhelon   (2002-04-29 08:48) [7]

На таких объёмах всё равно будет тормозить. Индексы помогут но тормоза остануться. Тут главное что надо понимать в SQL это то что чем меньше данных возвращает запрос тем быстрее он выполняется. А посему делай отбор более конкретный для узера.
Показывать юзеру >1000 записей не имеет смысла потому как они всё равно не воспринемаются визуально. Вот и думай что показывать (вибирать) а что не стоит.



Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2002.05.23;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.46 MB
Время: 0.006 c
1-73196
sir_musatov
2002-05-14 13:32
2002.05.23
поделитесь RxLib


1-73206
PShadow
2002-05-14 15:51
2002.05.23
Не могу запустить Excel


3-73026
ShaH
2002-04-26 12:34
2002.05.23
функции InterBase


1-73257
Дмитрий Иванов
2002-05-05 20:14
2002.05.23
TThread и Physical Memory


1-73180
sammy
2002-05-14 09:06
2002.05.23
Версия проекта





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский