|
|
Регистрация Восстановить пароль |
Повторная активизация e-mail |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
Опции темы | Поиск в этой теме |
21.07.2008, 08:56 | #1 |
Белик Виталий :)
Старожил
Регистрация: 23.07.2007
Сообщений: 57,097
|
Вопросы о оптимизации работы с СУБД
Доброго времени суток.
Вот зерно сомнений мне тут посеяли коллеги. В общем я утверждаю что запрос от клиента серверу типа Код:
Код:
Между клиентом и сервером 5 свичей Я прав в своих догадках? И еще вопрос: Если к серверу подключено 46 терминалов, все они интенсивно нагружают сервер запросами, работают с ним, то что лучше нагружать сервер чтоб он выполнял рассчет сложных функций, результаты которых являются частью запроса Код:
Код:
Ну и последний вопрос: Во в Делфи например подключение к БД делается примерно так: ADOQuery.Open отключение ADOQuery.close Вопрос: Что лучше держать подключение, не делая ADOQuery.close (при этом заставляя сервер держать подключения около 40 одновременно) или открыть, получить данные и закрыть (ADOQuery.close). Облегчит ли это нагрузку самого сервера СУБД? Ну и конечно спасибо за конструктивные ответы )
I'm learning to live...
|
21.07.2008, 10:14 | #2 | |||
Форумчанин
Регистрация: 15.06.2008
Сообщений: 271
|
Цитата:
Цитата:
Цитата:
|
|||
21.07.2008, 10:21 | #3 |
Белик Виталий :)
Старожил
Регистрация: 23.07.2007
Сообщений: 57,097
|
Ну-у-у НАйисчерпывающий ответ.
Благодарствую. Значит постораюсь настаивать на как можно меньшем количестве обращений, и закрытий сессий сразу же после получения данных. А если я не использую ADOConnection, а сразу через ADOQuery?
I'm learning to live...
|
21.07.2008, 10:50 | #4 | |
Delphi/C++/C#
Участник клуба
Регистрация: 29.10.2006
Сообщений: 1,972
|
Цитата:
|
|
21.07.2008, 10:57 | #5 |
Форумчанин
Регистрация: 15.06.2008
Сообщений: 271
|
Я закрываю датасет при закрытии формы, а не сразу после получения данных Т.е пока форма открыта, то открыт и датасет, чтобы пользователь мог работать с данными. А при закрытии приложения закрываю еще и ADOConnection.
|
21.07.2008, 11:02 | #6 |
Форумчанин
Регистрация: 15.06.2008
Сообщений: 271
|
zetrix, у ADOQuery есть свойство ConnectionString, которое можно настроить точно также, как и у ADOConnection. Хотя такой вариант я никогда не использвал. Подключение только через ADOConnection.
|
21.07.2008, 11:11 | #7 | |
Старожил
Регистрация: 09.01.2008
Сообщений: 26,229
|
Цитата:
to Stilet. Виталий, я полностью согласен с edgy - по классике жанра всю логику надо выносить на сервер - именно поэтому сервер должен быть многопроцессорный, иметь кучу памяти и прочая, прочая.. Хотя, как и везде, думаю, что существуют исключения - особенности, когда вынесение логики на клиента может разгрузить сервер (ну, разумеется, в том случае, когда величина выборки данных не зависит от этой вычисляемой функции!!!) и, чем меньше выборка и меньше полей в запросе - тем меньше нагрузка. |
|
21.07.2008, 11:29 | #8 |
Форумчанин
Регистрация: 15.02.2007
Сообщений: 183
|
объем данных
Сервер по своей сути предполагает большую загруженность, поэтому для сервера губительнее количество открытых сессий, но никак не вычисления и их количества и тем более объемы. Это сервер быстро посчитает, сохранит, если надо. Главное закрытие сессий по окончинии работы клиента с базой.
Знать все невозможно, в силу того, что жить бы стало неинтересно.
|
21.07.2008, 11:29 | #9 | |||
Белик Виталий :)
Старожил
Регистрация: 23.07.2007
Сообщений: 57,097
|
Цитата:
Цитата:
Цитата:
I'm learning to live...
|
|||
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Вопросы по оптимизации скорости | Иллидан | Общие вопросы Delphi | 9 | 11.07.2008 23:46 |
как создать субд в Delphi для работы с MySqL | Savl | БД в Delphi | 1 | 12.03.2008 14:10 |
Помощь в оптимизации | anger | Общие вопросы Delphi | 13 | 05.11.2007 13:15 |
задачи оптимизации | kirasir | Microsoft Office Excel | 2 | 08.08.2007 00:40 |