Mysql
 sql >> база данни >  >> RDS >> Mysql

Всеки начин за постигане на пълнотекстово търсене в InnoDB

използвайте таблица с пълен текст на myisam, за да индексирате обратно във вашите innodb таблици, например:

Изградете вашата система с помощта на innodb:

create table users (...) engine=innodb;

create table forums (...) engine=innodb;

create table threads
(
forum_id smallint unsigned not null,
thread_id int unsigned not null default 0,
user_id int unsigned not null,
subject varchar(255) not null, -- gonna want to search this... !!
created_date datetime not null,
next_reply_id int unsigned not null default 0,
view_count int unsigned not null default 0,
primary key (forum_id, thread_id) -- composite clustered PK index
)
engine=innodb;

Сега таблицата за пълнотекстово търсене, която ще използваме само за индексиране обратно в нашите innodb таблици. Можете да поддържате редове в тази таблица или като използвате задействане, или вечерни пакетни актуализации и т.н.

create table threads_ft
(
forum_id smallint unsigned not null,
thread_id int unsigned not null default 0,
subject varchar(255) not null,
fulltext (subject), -- fulltext index on subject
primary key (forum_id, thread_id) -- composite non-clustered index 
)
engine=myisam;

Накрая съхранената процедура за търсене, която извиквате от вашето php/приложение:

drop procedure if exists ft_search_threads;
delimiter #

create procedure ft_search_threads
(
in p_search varchar(255)
)
begin

select
 t.*,
 f.title as forum_title,
 u.username,
 match(tft.subject) against (p_search in boolean mode) as rank
from
 threads_ft tft
inner join threads t on tft.forum_id = t.forum_id and tft.thread_id = t.thread_id
inner join forums f on t.forum_id = f.forum_id
inner join users u on t.user_id = u.user_id
where
 match(tft.subject) against (p_search in boolean mode) 
order by 
 rank desc
limit 100;

end;

call ft_search_threads('+innodb +clustered +index');

Надявам се това да помогне :)



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Грешка 1046 Няма избрана база данни, как да се разреши?

  2. Как да използвам mysql_escape_string() в Yii рамка?

  3. Производителност на MySQL IN оператор върху (голям?) брой стойности

  4. Поръчайте в рамките на група от?

  5. Какъв е максималният размер на MySQL VARCHAR?