Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: оптимизация запроса

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
jonston
Отправлено: 18 Июня, 2012 - 11:33:55
Post Id



Посетитель


Покинул форум
Сообщений всего: 455
Дата рег-ции: Март 2011  


Помог: 3 раз(а)




Здравствуйте можно ли как нибудь оптимизировать следующий запрос?
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. CREATE TABLE `quiz_answers` (
  3.   `q_id` int(11) NOT NULL AUTO_INCREMENT,
  4.   `id` int(11) NOT NULL,
  5.   `to_widget_user_id` char(20) NOT NULL,
  6.   `to_widget_user_name` varchar(64) NOT NULL,
  7.   `date` int(11) NOT NULL,
  8.   `question` int(11) NOT NULL,
  9.   `answer` tinyint(2) NOT NULL,
  10.   `unlocked` tinyint(1) DEFAULT NULL,
  11.   `site_id` tinyint(3) UNSIGNED NOT NULL DEFAULT '0',
  12.   PRIMARY KEY (`q_id`),
  13.   UNIQUE KEY `answer`
  14. (`id`,`to_widget_user_id`,`question`,`answer`,`site_id`)
  15. )
  16.  
  17. SELECT count(*) FROM quiz_answers WHERE to_widget_user_id=100001804947780 AND
  18. site_id=35;
  19.  


-----
$i = 0;
$i = $i++ + ++$i; ?
 
 Top
Zuldek
Отправлено: 18 Июня, 2012 - 11:47:20
Post Id


Постоянный участник


Покинул форум
Сообщений всего: 2122
Дата рег-ции: Июнь 2010  


Помог: 50 раз(а)




Запроса тут 2.
Select оптимизировать некуда.
 
 Top
Мелкий Супермодератор
Отправлено: 18 Июня, 2012 - 12:00:11
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Zuldek пишет:
Select оптимизировать некуда.

Отчего же? Fullscan ведь.
Индекс по site_id и to_widget_user_id увеличит производительность тем ощутимее, чем больше лишних строк сейчас читается.
+ надо поглядеть на explain в вариантах select count(0), select count(to_widget_user_id), select count(site_id). Может, удастся к index scan свести всю работу.

И сбивает с мысли to_widget_user_id, который почему-то char


-----
PostgreSQL DBA
 
 Top
Zuldek
Отправлено: 18 Июня, 2012 - 12:27:35
Post Id


Постоянный участник


Покинул форум
Сообщений всего: 2122
Дата рег-ции: Июнь 2010  


Помог: 50 раз(а)





это жеж уже оптимизация структуры данных а не запроса на выборку Улыбка

(Отредактировано автором: 18 Июня, 2012 - 12:27:59)

 
 Top
Мелкий Супермодератор
Отправлено: 18 Июня, 2012 - 12:47:17
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)





Zuldek, нет, именно запроса. Для структуры данных неуникальные индексы бесполезны и вовсе лишняя информация.


-----
PostgreSQL DBA
 
 Top
Champion Супермодератор
Отправлено: 18 Июня, 2012 - 13:00:45
Post Id



Активный участник


Покинул форум
Сообщений всего: 4350
Дата рег-ции: Авг. 2008  
Откуда: Москва


Помог: 57 раз(а)




Еще вариант - чтобы не создавать лишний индекс просто поменять порядок полей в UNIQUE KEY. Нужно site_id и to_widget_user_id поставить первыми. Это конечно если этот индекс специально так не оптимизирован под какие-то другие запросы
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB