Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> оптимизация запроса, использование select count(*) 
:(
    Опции темы
Vidocq
Дата 11.4.2006, 19:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 431
Регистрация: 15.12.2004
Где: Запорожье, Украин а

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



Есть запрос smile
Код

select  ls.name as servername, lst.name as platform, lsi.ip as serverip,
        (select count(l_server_id) from l_server_ips where l_server_id=ls.id) as totalips,
        (select count(l_server_id) from l_server_ips where l_server_id=ls.id and flag!=0) as ips_used,
        (select count(l_server_id) from l_server_ips where l_server_id=ls.id)-(select count(l_server_id) from l_server_ips where l_server_id=ls.id and flag!=0) as ips_free,
        cast((select count(l_server_id) from l_server_ips where l_server_id=ls.id and flag!=0) as real)/(select count(l_server_id) from l_server_ips where l_server_id=ls.id)*100 as ips_used_percent,
        ls.signup as signup
        from l_server ls
        join l_server_types lst on ls.type_id=lst.id
        join l_server_groups lsg on (ls.group_id=lsg.id and (lsg.name='web servers' or lsg.name='win servers'))
        join l_server_ips lsi on (ls.id=lsi.l_server_id and lsi.flag=2)


Но работает очень долго. Как его можно оптимизировать?


--------------------
Всё течёт ©
PM MAIL ICQ   Вверх
LSD
Дата 11.4.2006, 19:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

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



СУБД какая?


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Vit
Дата 11.4.2006, 19:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


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

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



Vidocq, стыдно! Вы же не новичёк на форуме, а такой простой вещи как прочитать правила раздела в рамочке не соизволили! Пока только устное предупреждение, следующий раз такие сообщения будут идти сразу в корзину!


--------------------
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   Вверх
chief39
Дата 11.4.2006, 20:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

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



Цитата(LSD @ 11.4.2006, 19:23 Найти цитируемый пост)
СУБД какая?

Глаголеть мне моя интуиция, что это сибэйс или М$ smile

Vidocq, Вроде никак. Сам текст. Надо будет ещё раз на свежую голову взглянуть.
Индексы неплохо бы создать, если их нет. По айдишкам, и юзаемым полям в условиях.
И поглядеть план запроса.
Хотя сервер и не дурак... но мало ли... если он соберёт всё в кучу - получит баальшой датарет, а потом начнёт выискивать по текстовым полям нэймы групп - будет долго smile текст савнить - это не число smile
А реально такую ситуацию как-то наблюдал smile


--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
Vidocq
Дата 12.4.2006, 09:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 431
Регистрация: 15.12.2004
Где: Запорожье, Украин а

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



Vit,
Прошу прощения. Постил после рабочего дня, голова совсем глупая была.

База данных: Postgres 8.0.4
Способ доступа: PEAR, если правильно понял.
Среда программирования: php 5.1.2


--------------------
Всё течёт ©
PM MAIL ICQ   Вверх
chief39
Дата 12.4.2006, 10:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

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



Цитата(Vidocq @ 12.4.2006, 09:52 Найти цитируемый пост)
База данных: Postgres 8.0.4

Мдя.. не угадал smile
Глядел планы запросов?


--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
Vidocq
Дата 12.4.2006, 11:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 431
Регистрация: 15.12.2004
Где: Запорожье, Украин а

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



Код



QUERY PLAN
----------------------------------------------------------------------------------------------------------------------------
 Hash Join  (cost=8.06..1975.69 rows=19 width=75)
   Hash Cond: ("outer".l_server_id = "inner".id)
   ->  Seq Scan on l_server_ips lsi  (cost=0.00..1966.85 rows=109 width=20)
         Filter: (flag = 2)
   ->  Hash  (cost=8.01..8.01 rows=19 width=55)
         ->  Hash Join  (cost=2.19..8.01 rows=19 width=55)
               Hash Cond: ("outer".group_id = "inner".id)
               ->  Hash Join  (cost=1.02..6.05 rows=110 width=51)
                     Hash Cond: ("outer".type_id = "inner".id)
                     ->  Seq Scan on l_server ls  (cost=0.00..3.10 rows=110 width=37)
                     ->  Hash  (cost=1.02..1.02 rows=2 width=14)
                           ->  Seq Scan on l_server_types lst  (cost=0.00..1.02 rows=2 width=14)
               ->  Hash  (cost=1.17..1.17 rows=2 width=4)
                     ->  Seq Scan on l_server_groups lsg  (cost=0.00..1.17 rows=2 width=4)
                           Filter: ((name = 'web servers'::character varying) OR (name = 'win servers'::character varying))
   SubPlan
     ->  Aggregate  (cost=966.28..966.28 rows=1 width=4)
           ->  Index Scan using l_server_ips_ref on l_server_ips  (cost=0.00..963.65 rows=1050 width=4)
                 Index Cond: (l_server_id = $0)
     ->  Aggregate  (cost=968.61..968.61 rows=1 width=4)
           ->  Index Scan using l_server_ips_ref on l_server_ips  (cost=0.00..966.28 rows=932 width=4)
                 Index Cond: (l_server_id = $0)
                 Filter: (flag <> 0)
     ->  Aggregate  (cost=966.28..966.28 rows=1 width=4)
           ->  Index Scan using l_server_ips_ref on l_server_ips  (cost=0.00..963.65 rows=1050 width=4)
                 Index Cond: (l_server_id = $0)
     ->  Aggregate  (cost=968.61..968.61 rows=1 width=4)
           ->  Index Scan using l_server_ips_ref on l_server_ips  (cost=0.00..966.28 rows=932 width=4)
                 Index Cond: (l_server_id = $0)
                 Filter: (flag <> 0)
     ->  Aggregate  (cost=968.61..968.61 rows=1 width=4)
           ->  Index Scan using l_server_ips_ref on l_server_ips  (cost=0.00..966.28 rows=932 width=4)
                 Index Cond: (l_server_id = $0)
                 Filter: (flag <> 0)
     ->  Aggregate  (cost=966.28..966.28 rows=1 width=4)
           ->  Index Scan using l_server_ips_ref on l_server_ips  (cost=0.00..963.65 rows=1050 width=4)
                 Index Cond: (l_server_id = $0)
(37 rows)

Мне это мало что говорит smile


Это сообщение отредактировал(а) Vidocq - 12.4.2006, 11:23


--------------------
Всё течёт ©
PM MAIL ICQ   Вверх
Ortega
Дата 25.4.2006, 21:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 115
Регистрация: 5.11.2005
Где: Харьков, Украина

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



Цитата(chief39 @  11.4.2006,  20:24 Найти цитируемый пост)
получит баальшой датарет, а потом начнёт выискивать по текстовым полям нэймы групп - будет долго smile текст савнить - это не число

Действительно, попробуй поиграться с порядком join'ов. В зависимости от того, сколько обрежет проверка по группам, помести ее либо в начало (если бОльшую часть либо очень много) либо в конец (в другом случае).
Кстати, заметил еще одну вещь у тебя: примерно в половине вложенных запросов ты используешь кусок 
Код

from l_server_ips where l_server_id=ls.id and flag!=0
 
и в то же время в общем запросе ты накладываешь условие 
Код

lsi.flag=2
 то есть во вложенных запросах ты выбираешь много лишнего. Вывод: если есть возможность изменить запрос, используй
Код

from l_server_ips where l_server_id=ls.id and flag=2
 
--------------------
Всему свое время (с) ЧайфНе парься, будь счастлив (с) Пеппи Длинный Чулок
PM MAIL WWW ICQ Skype GTalk   Вверх
igon
Дата 26.4.2006, 07:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



В Oracle я бы попробовал так:
Код

Select a.id, a.ips_used + a.ips_not_used totalips, a.ips_used, a.ips_not_used, a.ips_used*100/(a.ips_used + a.ips_not_used) ips_used_percent
  From (select  ls.id, Sum(Case When flag>0 Then 1 Else 0 End) ips_used, Sum(Case When flag>0 Then 0 Else 1 End) ips_not_used 
          From l_server ls, l_server_ips lsi
          Where ls.id=lsi.l_server_id
          Group By ls.id) a

Этот Select можно оформить в виде View или прямо так добавить в виде еще одного Join.
Работать вроде должно быстрее, но на массивных данных не проверял.
А вот как это все в Postgre должно выглядеть -  smile 
 


--------------------
Хотите поговорить об этом?
PM   Вверх
madFobos
Дата 2.5.2006, 23:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



А ты индексы используешь? 
PM MAIL   Вверх
Akina
Дата 3.5.2006, 09:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

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



У тебя постоянно фигурирует
Код
(select count(l_server_id) from l_server_ips where l_server_id=ls.id)
и
Код
(select count(l_server_id) from l_server_ips where l_server_id=ls.id and flag!=0)
Может имеет смысл сделать группированную выборку как еще один связанный источник?
Код

select ...
from ...
join ...
join (select l_server_id, flag, count(l_server_id) as clsi from l_server_ips group by l_server_id, flag) lsx on ls.id=lsx.l_server_id
  


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


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

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


 




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


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

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