Sphinxsearch:加入 3 个表

Posted

技术标签:

【中文标题】Sphinxsearch:加入 3 个表【英文标题】:Sphinxsearch: joining 3 tables 【发布时间】:2016-02-14 18:11:44 【问题描述】:

我有 3 个表:CV, CvSkill, Skill. CvSkill 是其他两个表之间的多对多映射表。所以我想要实现的是,当用户搜索技能时,使用 Sphinx 获取所有与搜索技能相关的简历。用户也可以在技能中输入错误的内容。 Sphinx 必须通过接近度匹配输入的技能,并获得最大相关技能的 CV 结果。

我不知道如何配置 sphinx (etc/sphinxsearch/sphinx.conf) 以这种方式进行搜索。

有什么建议吗?

CREATE TABLE `CV` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `fullName` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL COMMENT 'Ad, soyad'
) ENGINE=InnoDB AUTO_INCREMENT=55 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci ROW_FORMAT=COMPACT;


CREATE TABLE `CvSkill` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `cvID` int(10) unsigned DEFAULT NULL,
  `skillID` int(10) unsigned DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `CS_UK1` (`cvID`,`skillID`),
  KEY `skill_id` (`skillID`),
  CONSTRAINT `CS_FK1` FOREIGN KEY (`cvID`) REFERENCES `CV` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
  CONSTRAINT `CS_FK2` FOREIGN KEY (`skillID`) REFERENCES `Skill` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB AUTO_INCREMENT=48 DEFAULT CHARSET=utf8;

CREATE TABLE `Skill` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL,
  `slug` varchar(255) DEFAULT NULL,
  `logoImg` varchar(255) DEFAULT NULL,
  `color` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `name` (`name`),
  UNIQUE KEY `slug` (`slug`)
) ENGINE=InnoDB AUTO_INCREMENT=39 DEFAULT CHARSET=utf8;

SET FOREIGN_KEY_CHECKS = 1;

提前致谢

【问题讨论】:

【参考方案1】:

可以加入表格..

sql_query = SELECT CV.id,GROUP_CONCAT(Skill.name SEPARATOR '. ') as skill \
  FROM CV \
  INNER JOIN CvSkill ON (cvID = CV.id) \
  INNER JOIN Skill ON (skillID = Skill.id) \
  GROUP BY CV.id \
  ORDER BY NULL 

当然可能希望其他字段能够搜索,但以上只是一个开始。

【讨论】:

CvSkill 表是否用于查询?我没看到 是的,你在加入条件中需要它。因为它包含简历和技能表之间的链接 小心 GROUP_CONCAT() 有一个 LENGTH 限制(不是计数限制) * dev.mysql.com/doc/refman/5.7/en/… * ***.com/questions/23608464/group-concat-with-limit * ***.com/questions/2567000/…

以上是关于Sphinxsearch:加入 3 个表的主要内容,如果未能解决你的问题,请参考以下文章

搜索查询加入 3 个表,1 个表有日期

加入 3 个表时出现错误 1066

实体框架加入3个表

如何打印加入 JDBC 的 3 个表中的列名? [复制]

Laravel 加入 3 个表

mysql 加入 3 个表,但“COUNT”重复