This commit is contained in:
杨志
2026-01-06 16:18:23 +08:00
parent 322b171378
commit 3b46b6d77d

View File

@@ -285,7 +285,8 @@ class MatchService
$majorCodeMap = []; $majorCodeMap = [];
$majorCodes = []; $majorCodes = [];
foreach ($educations as $education) { foreach ($educations as $education) {
$codeFields = ['major_code', 'majors_code', 'code', 'major_id', 'majors_id', 'major_no']; // 收集所有可能的专业代码字段
$codeFields = ['major_code', 'majors_code', 'code', 'major_id', 'majors_id', 'major_no', 'id'];
foreach ($codeFields as $field) { foreach ($codeFields as $field) {
if (!empty($education[$field])) { if (!empty($education[$field])) {
$majorCodes[] = $education[$field]; $majorCodes[] = $education[$field];
@@ -295,24 +296,53 @@ class MatchService
$majorCodes = array_values(array_unique($majorCodes)); $majorCodes = array_values(array_unique($majorCodes));
if (!empty($majorCodes)) { if (!empty($majorCodes)) {
try {
// 尝试多种可能的查询字段id, code, major_code, majors_id
$majors = [];
$queryFields = ['id', 'code', 'major_code', 'majors_id', 'major_id'];
foreach ($queryFields as $queryField) {
try { try {
$majors = Db::name('da_majors') $majors = Db::name('da_majors')
->whereIn('code', $majorCodes) ->whereIn($queryField, $majorCodes)
->select() ->select()
->toArray(); ->toArray();
if (!empty($majors)) {
error_log("成功从da_majors表查询到 " . count($majors) . " 条专业记录,使用字段: {$queryField}");
break; // 找到匹配的字段,退出循环
}
} catch (\Exception $e) {
// 字段不存在,继续尝试下一个
continue;
}
}
// 构建专业代码映射表
foreach ($majors as $major) { foreach ($majors as $major) {
$code = $major['code'] ?? $major['major_code'] ?? null; // 尝试多种可能的代码字段
$code = $major['id'] ?? $major['code'] ?? $major['major_code'] ?? $major['majors_id'] ?? $major['major_id'] ?? null;
if (!$code) { if (!$code) {
continue; continue;
} }
// 尝试多种可能的名称字段
$name = $major['major_name'] ?? $major['name'] ?? $major['title'] ?? $major['专业名称'] ?? '';
// 尝试多种可能的类别字段
$category = $major['category_name'] ?? $major['category'] ?? $major['major_category'] ?? $major['专业类别'] ?? $major['学科类别'] ?? '';
$majorCodeMap[$code] = [ $majorCodeMap[$code] = [
'name' => $major['major_name'] ?? $major['name'] ?? $major['title'] ?? '', 'name' => $name,
'category' => $major['category_name'] ?? $major['category'] ?? $major['major_category'] ?? '', 'category' => $category,
]; ];
} }
error_log("专业代码映射表构建完成,共 " . count($majorCodeMap) . " 条记录");
} catch (\Exception $e) { } catch (\Exception $e) {
// da_majors 表不存在或字段不匹配时忽略 error_log("查询da_majors表失败: " . $e->getMessage());
} }
} else {
error_log("未找到专业代码无法查询da_majors表");
} }
// 构建简历数据结构 // 构建简历数据结构
@@ -347,15 +377,22 @@ class MatchService
// 如果有专业代码但没有名称,尝试从 da_majors 映射获取 // 如果有专业代码但没有名称,尝试从 da_majors 映射获取
if (empty($majorName)) { if (empty($majorName)) {
$codeFields = ['major_code', 'majors_code', 'code', 'major_id', 'majors_id', 'major_no']; $codeFields = ['major_code', 'majors_code', 'code', 'major_id', 'majors_id', 'major_no', 'id'];
foreach ($codeFields as $field) { foreach ($codeFields as $field) {
if (!empty($education[$field]) && isset($majorCodeMap[$education[$field]])) { if (!empty($education[$field])) {
$majorName = $majorCodeMap[$education[$field]]['name'] ?? ''; $codeValue = $education[$field];
$education['major_category'] = $majorCodeMap[$education[$field]]['category'] ?? ''; // 尝试直接匹配
if (isset($majorCodeMap[$codeValue])) {
$majorName = $majorCodeMap[$codeValue]['name'] ?? '';
$education['major_category'] = $majorCodeMap[$codeValue]['category'] ?? '';
if (!empty($majorName)) {
error_log("从majorCodeMap获取到专业名称: {$majorName}, 代码: {$codeValue}");
break; break;
} }
} }
} }
}
}
// 保存专业代码,便于后续调试 // 保存专业代码,便于后续调试
$majorCode = ''; $majorCode = '';