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]   

> Без описания
Еугений
Отправлено: 29 Января, 2016 - 01:56:14
Post Id


Частый гость


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


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




Работаю над реализацией тегов, добавил две таблицы tags (id, tag_name) , tag_to_post (tag_id, post_id)
Вот теперь думаю как правильно добавить индексы, вроде в них в данном случае нуждается только таблица tag_to_post.

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

Какая самая выигрышная в плане и скорости нагрузки расстановка индексов? Хватит ли одного индекса на tag_id или на post_id в таблице tag_to_post? Или совместный индекс?

а если я на оба повешу primary key, то это отразиться на скорости? Это тоже индексирование?

(Отредактировано автором: 29 Января, 2016 - 02:10:26)

 
 Top
Мелкий Супермодератор
Отправлено: 29 Января, 2016 - 08:59:14
Post Id



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


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


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




primary key - это уникальный индекс.
Если говорить про mysql и innodb - то данные в таблице лежат неотрывно от первичного индекса. И все другие индексы ссылаются на первичный ключ, а не на непосредственно данные.

выборка постов по тегу - tag_id & post_id
выборка тегов к посту: post_id & tag_id

Если один из этих индексов сделать первичным, то второй индекс из-за свойств первичного ключа можно сократить только до первого поля. Например, tag & post - PK, и отдельно индекс по post_id.
Какой именно сделать первичным - собственно, определяющего значения не имеет.


-----
PostgreSQL DBA
 
 Top
Еугений
Отправлено: 29 Января, 2016 - 15:07:59
Post Id


Частый гость


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


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




Мелкий пишет:
primary key - это уникальный индекс.
Если говорить про mysql и innodb - то данные в таблице лежат неотрывно от первичного индекса. И все другие индексы ссылаются на первичный ключ, а не на непосредственно данные.

выборка постов по тегу - tag_id & post_id
выборка тегов к посту: post_id & tag_id

Если один из этих индексов сделать первичным, то второй индекс из-за свойств первичного ключа можно сократить только до первого поля. Например, tag & post - PK, и отдельно индекс по post_id.
Какой именно сделать первичным - собственно, определяющего значения не имеет.


Если я сделаю только РК, который добавляется как то так primary (tag_id, post_id) , то выборка после этого будет быстра только по полю tag_id? и поэтому надо бы добавить еще отдельно индекс на post_id?
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Работа с СУБД »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB