首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Sphinxsearch:连接3个表

Sphinxsearch:连接3个表
EN

Stack Overflow用户
提问于 2015-11-13 15:58:07
回答 1查看 149关注 0票数 1

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

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

有什么建议吗?

代码语言:javascript
复制
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;

提前感谢

EN

回答 1

Stack Overflow用户

发布于 2015-11-13 19:31:31

可以加入到表中..

代码语言:javascript
复制
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 

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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33688058

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档