gpt4 book ai didi

mysql - sphinx 搜索 : joining 3 tables

转载 作者:行者123 更新时间:2023-11-28 23:45:20 25 4
gpt4 key购买 nike

我有 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;

提前致谢

最佳答案

可以加入表格..

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

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

关于mysql - sphinx 搜索 : joining 3 tables,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33688058/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com