alert('阿里旺旺为必填项');history.back();"; exit; } // Website source validation if (strpos($cs_code, '官网') !== false) { $cs_from = 3; } if ($cs_from == 3 && empty($tel_1) && empty($whatsapp_1) && empty($wechat_1)) { echo ""; exit; } // Market customer validation if ($cs_from == 8 && empty($wechat_1)) { echo ""; exit; } // Facebook validation if ($cs_from == 12 && empty($facebook_1)) { echo ""; exit; } } // Determine action type $act = empty($id) || !is_numeric($id) ? 'addSave' : 'editSave'; if ($act === 'editSave') { // Verify customer ownership - 将bind_param改为SQL拼接 $id = intval($id); // 确保ID是整数,防止SQL注入 $sql = "SELECT cs_belong FROM customer WHERE id = " . $id; $result = $conn->query($sql); if ($row = $result->fetch_assoc()) { if ($row['cs_belong'] != $cs_belong) { echo ""; exit; } } else { echo ""; exit; } } // Validate customer code if (empty($cs_code)) { echo ""; exit; } $customer_id = is_numeric($id) ? intval($id) : 0; // Check for duplicate customer information $checkStr = "SELECT c.*, cc.* FROM customer c LEFT JOIN customer_contact cc ON c.id = cc.customer_id WHERE c.id != " . $customer_id." AND ( 1=2 "; $Dupli = ""; /* 暂时不需要这些检查 START */ // Company name similarity check //if (!empty($cs_company)) { // $companyWords = explode(' ', strtolower($cs_company)); // foreach ($companyWords as $word) { // if (strlen($word) > 3) { // Only check words longer than 3 characters // $checkStr .= " OR LOWER(c.cs_company) LIKE '%" . $conn->real_escape_string($word) . "%'"; // } // } //} // Address similarity check //if (!empty($cs_address)) { // $addressWords = explode(' ', strtolower($cs_address)); // foreach ($addressWords as $word) { // if (strlen($word) > 3) { // Only check words longer than 3 characters // $checkStr .= " OR LOWER(c.cs_address) LIKE '%" . $conn->real_escape_string($word) . "%'"; // } // } //} /* 暂时不需要这些检查 END */ // Check all contacts for duplicates foreach ($contacts as $contact) { //遍历处理空格 foreach ($contact as $key => $value) { $contact[$key] = trim($value); } // Check all phone numbers for ($i = 1; $i <= 3; $i++) { $tel_field = 'tel_' . $i; if (!empty($contact[$tel_field])) { $tel_format = numFormat($contact[$tel_field]); // Remove country code and spaces for better matching $tel_clean = preg_replace('/[^0-9]/', '', $tel_format); if(!empty($tel_clean)) { $checkStr .= " OR cc.tel_1_format LIKE '%" . substr($tel_clean, -9) . "%'" . " OR cc.tel_2_format LIKE '%" . substr($tel_clean, -9) . "%'" . " OR cc.tel_3_format LIKE '%" . substr($tel_clean, -9) . "%'" . " OR cc.wechat_1 LIKE '%" . substr($tel_clean, -9) . "%'" . " OR cc.wechat_2 LIKE '%" . substr($tel_clean, -9) . "%'" . " OR cc.wechat_3 LIKE '%" . substr($tel_clean, -9) . "%'"; $Dupli .= "电话" . $i . ":" . $contact[$tel_field] . " "; } } } // Check all email addresses for ($i = 1; $i <= 3; $i++) { $email_field = 'email_' . $i; if (!empty($contact[$email_field])) { $contact[$email_field]=trim($contact[$email_field]); $email = strtolower($contact[$email_field]); $checkStr .= " OR LOWER(cc.email_1) = '" . $conn->real_escape_string($email) . "'" . " OR LOWER(cc.email_2) = '" . $conn->real_escape_string($email) . "'" . " OR LOWER(cc.email_3) = '" . $conn->real_escape_string($email) . "'"; $Dupli .= "邮箱" . $i . ":" . $contact[$email_field] . " "; } } // Check all WhatsApp numbers for ($i = 1; $i <= 3; $i++) { $whatsapp_field = 'whatsapp_' . $i; if (!empty($contact[$whatsapp_field])) { $whatsapp_format = numFormat($contact[$whatsapp_field]); $whatsapp_clean = preg_replace('/[^0-9]/', '', $whatsapp_format); if(!empty($whatsapp_clean)) { $checkStr .= " OR cc.whatsapp_1_format LIKE '%" . substr($whatsapp_clean, -9) . "%'" . " OR cc.whatsapp_2_format LIKE '%" . substr($whatsapp_clean, -9) . "%'" . " OR cc.whatsapp_3_format LIKE '%" . substr($whatsapp_clean, -9) . "%'" . " OR cc.tel_1_format LIKE '%" . substr($whatsapp_clean, -9) . "%'" . " OR cc.tel_2_format LIKE '%" . substr($whatsapp_clean, -9) . "%'" . " OR cc.tel_3_format LIKE '%" . substr($whatsapp_clean, -9) . "%'"; $Dupli .= "WhatsApp" . $i . ":" . $contact[$whatsapp_field] . " "; } } } // Check all WeChat accounts for ($i = 1; $i <= 3; $i++) { $wechat_field = 'wechat_' . $i; if (!empty($contact[$wechat_field])) { $wechat = $contact[$wechat_field]; $checkStr .= " OR cc.wechat_1 LIKE '%" . $conn->real_escape_string($wechat) . "%'" . " OR cc.wechat_2 LIKE '%" . $conn->real_escape_string($wechat) . "%'" . " OR cc.wechat_3 LIKE '%" . $conn->real_escape_string($wechat) . "%'" . " OR cc.tel_1_format LIKE '%" . $conn->real_escape_string($wechat) . "%'" . " OR cc.tel_2_format LIKE '%" . $conn->real_escape_string($wechat) . "%'" . " OR cc.tel_3_format LIKE '%" . $conn->real_escape_string($wechat) . "%'"; $Dupli .= "微信" . $i . ":" . $contact[$wechat_field] . " "; } } // Check all LinkedIn accounts for ($i = 1; $i <= 3; $i++) { $linkedin_field = 'linkedin_' . $i; if (!empty($contact[$linkedin_field])) { $linkedin = strtolower($contact[$linkedin_field]); $checkStr .= " OR LOWER(cc.linkedin_1) LIKE '%" . $conn->real_escape_string($linkedin) . "%'" . " OR LOWER(cc.linkedin_2) LIKE '%" . $conn->real_escape_string($linkedin) . "%'" . " OR LOWER(cc.linkedin_3) LIKE '%" . $conn->real_escape_string($linkedin) . "%'"; $Dupli .= "LinkedIn" . $i . ":" . $contact[$linkedin_field] . " "; } } // Check all Facebook accounts for ($i = 1; $i <= 3; $i++) { $facebook_field = 'facebook_' . $i; if (!empty($contact[$facebook_field])) { $facebook = strtolower($contact[$facebook_field]); $checkStr .= " OR LOWER(cc.facebook_1) LIKE '%" . $conn->real_escape_string($facebook) . "%'" . " OR LOWER(cc.facebook_2) LIKE '%" . $conn->real_escape_string($facebook) . "%'" . " OR LOWER(cc.facebook_3) LIKE '%" . $conn->real_escape_string($facebook) . "%'"; $Dupli .= "Facebook" . $i . ":" . $contact[$facebook_field] . " "; } } // Check all Alibaba accounts for ($i = 1; $i <= 3; $i++) { $alibaba_field = 'alibaba_' . $i; if (!empty($contact[$alibaba_field])) { $alibaba = strtolower($contact[$alibaba_field]); if (strlen($alibaba) < 10) { $checkStr .= " OR LOWER(cc.alibaba_1) LIKE '" . $conn->real_escape_string($alibaba) . "'" . " OR LOWER(cc.alibaba_2) LIKE '" . $conn->real_escape_string($alibaba) . "'" . " OR LOWER(cc.alibaba_3) LIKE '" . $conn->real_escape_string($alibaba) . "'"; } else { $alibaba_clean = preg_replace('/[^0-9a-zA-Z]/', '', $alibaba); $checkStr .= " OR LOWER(cc.alibaba_1) LIKE '%" . substr($alibaba_clean, -9) . "%'" . " OR LOWER(cc.alibaba_2) LIKE '%" . substr($alibaba_clean, -9) . "%'" . " OR LOWER(cc.alibaba_3) LIKE '%" . substr($alibaba_clean, -9) . "%'"; } $Dupli .= "阿里旺旺" . $i . ":" . $contact[$alibaba_field] . " "; } } } $checkStr .= " ) ORDER BY c.id ASC"; if ($allowedit != 1) { $result = $conn->query($checkStr); if ($result && $result->num_rows > 0) { $row = $result->fetch_assoc(); // Get owner name $ownerResult = $conn->query("SELECT em_user FROM employee WHERE id = " . $row['cs_belong']); $ownerRow = $ownerResult->fetch_assoc(); $owner = textUncode($ownerRow['em_user']); // Determine who entered first if (strtotime($cs_addtime) > strtotime($row['cs_addtime'])) { $tstr = "INSERT INTO logrecord (loginName, loginIp, loginTime, loginAct) VALUES ('" . $_SESSION['employee_name'] . "', '" . getIp() . "', '" . date('Y-m-d H:i:s') . "', '" . $_SESSION['employee_name'] . "编辑客户\"" . $cs_code . "\",该客户与\"" . textUncode($row['cs_code']) . "\"高度类似,
重复项为:" . $Dupli . "
客户由:" . $_SESSION['employee_name'] . $cs_addtime . "首次录入')"; } else { $tstr = "INSERT INTO logrecord (loginName, loginIp, loginTime, loginAct) VALUES ('" . $_SESSION['employee_name'] . "', '" . getIp() . "', '" . date('Y-m-d H:i:s') . "', '" . $_SESSION['employee_name'] . "编辑客户\"" . $cs_code . "\",该客户与\"" . textUncode($row['cs_code']) . "\"高度类似,
重复项为:" . $Dupli . "
客户由:" . $owner . $row['cs_addtime'] . "首次录入')"; } $conn->query($tstr); echo ""; exit; } else { //全文检索再检查一次 //先去掉联系方式中的特殊字符 //用联系方式进行全文fullindex检索,用相关性分数大于百分70 的进行检查 // 根据不同联系方式类型进行专门检查 $duplicateFound = false; $matchDetails = ''; $matchScore = 0; $matchCustomerId = 0; $matchCustomerCode = ''; $matchOwner = ''; $matchAddTime = ''; // 编辑模式下需要排除自己的ID $excludeId = ($act === 'editSave' && is_numeric($id)) ? intval($id) : 0; // 1. 优先检查邮箱 - 邮箱是最精确的匹配 $emailTerms = []; foreach ($contacts as $contact) { for ($i = 1; $i <= 3; $i++) { $field = 'email_' . $i; if (!empty($contact[$field])) { $email = strtolower(trim($contact[$field])); if (strpos($email, '@') !== false) { $emailTerms[] = $email; } } } } if (!empty($emailTerms)) { $emailQuery = "SELECT c.id, c.cs_code, c.cs_belong, c.cs_addtime, cc.email_1, cc.email_2, cc.email_3 FROM customer c JOIN customer_contact cc ON c.id = cc.customer_id WHERE c.cs_belong != " . $_SESSION['employee_id'] . " AND c.id != " . $excludeId . " AND ("; $emailConditions = []; foreach ($emailTerms as $email) { $emailConditions[] = "cc.email_1 = '" . $conn->real_escape_string($email) . "'"; $emailConditions[] = "cc.email_2 = '" . $conn->real_escape_string($email) . "'"; $emailConditions[] = "cc.email_3 = '" . $conn->real_escape_string($email) . "'"; } $emailQuery .= implode(" OR ", $emailConditions) . ") LIMIT 1"; $emailResult = $conn->query($emailQuery); if ($emailResult && $emailResult->num_rows > 0) { $row = $emailResult->fetch_assoc(); $matchCustomerId = $row['id']; $matchCustomerCode = $row['cs_code']; $matchOwner = $row['cs_belong']; $matchAddTime = $row['cs_addtime']; $matchDetails = "邮箱完全匹配"; $matchScore = 0.95; // 邮箱精确匹配,高可信度 $duplicateFound = true; } } // 2. 检查电话号码与WhatsApp - 清理后进行后缀匹配 if (!$duplicateFound) { $phoneTerms = []; foreach ($contacts as $contact) { // 收集所有电话号码 for ($i = 1; $i <= 3; $i++) { $fields = ['tel_' . $i, 'whatsapp_' . $i]; foreach ($fields as $field) { if (!empty($contact[$field])) { $cleaned = preg_replace('/[^0-9]/', '', $contact[$field]); if (strlen($cleaned) > 7) { // 至少8位有效数字 $phoneTerms[] = $cleaned; } } } } } if (!empty($phoneTerms)) { $phoneQuery = "SELECT c.id, c.cs_code, c.cs_belong, c.cs_addtime, cc.tel_1_format, cc.tel_2_format, cc.tel_3_format, cc.whatsapp_1_format, cc.whatsapp_2_format, cc.whatsapp_3_format FROM customer c JOIN customer_contact cc ON c.id = cc.customer_id WHERE c.cs_belong != " . $_SESSION['employee_id'] . " AND c.id != " . $excludeId . " AND ("; $phoneConditions = []; foreach ($phoneTerms as $phone) { // 使用后8位进行匹配,避免国家代码等差异 $suffix = substr($phone, -8); if (strlen($suffix) == 8) { $phoneConditions[] = "cc.tel_1_format LIKE '%" . $conn->real_escape_string($suffix) . "'"; $phoneConditions[] = "cc.tel_2_format LIKE '%" . $conn->real_escape_string($suffix) . "'"; $phoneConditions[] = "cc.tel_3_format LIKE '%" . $conn->real_escape_string($suffix) . "'"; $phoneConditions[] = "cc.whatsapp_1_format LIKE '%" . $conn->real_escape_string($suffix) . "'"; $phoneConditions[] = "cc.whatsapp_2_format LIKE '%" . $conn->real_escape_string($suffix) . "'"; $phoneConditions[] = "cc.whatsapp_3_format LIKE '%" . $conn->real_escape_string($suffix) . "'"; } } if (!empty($phoneConditions)) { $phoneQuery .= implode(" OR ", $phoneConditions) . ") LIMIT 1"; $phoneResult = $conn->query($phoneQuery); if ($phoneResult && $phoneResult->num_rows > 0) { $row = $phoneResult->fetch_assoc(); $matchCustomerId = $row['id']; $matchCustomerCode = $row['cs_code']; $matchOwner = $row['cs_belong']; $matchAddTime = $row['cs_addtime']; $matchDetails = "电话号码后8位匹配"; $matchScore = 0.90; // 电话匹配,高可信度 $duplicateFound = true; } } } } // 3. 检查社交媒体账号 (alibaba/wechat/facebook/linkedin) if (!$duplicateFound) { $socialTerms = []; $socialFields = [ 'alibaba' => '阿里旺旺', 'wechat' => '微信', 'facebook' => 'Facebook', 'linkedin' => 'LinkedIn' ]; foreach ($contacts as $contact) { foreach ($socialFields as $field => $label) { for ($i = 1; $i <= 3; $i++) { $fieldName = $field . '_' . $i; if (!empty($contact[$fieldName])) { $value = trim($contact[$fieldName]); if (strlen($value) > 3) { // 至少4个字符 $socialTerms[] = [ 'type' => $field, 'label' => $label, 'value' => $value ]; } } } } } if (!empty($socialTerms)) { foreach ($socialTerms as $term) { $field = $term['type']; $value = $term['value']; $label = $term['label']; // 根据社交媒体类型构建不同的查询 $socialQuery = "SELECT c.id, c.cs_code, c.cs_belong, c.cs_addtime FROM customer c JOIN customer_contact cc ON c.id = cc.customer_id WHERE c.cs_belong != " . $_SESSION['employee_id'] . " AND c.id != " . $excludeId . " AND ("; // 根据社交账号类型确定匹配方式 if ($field == 'alibaba' || $field == 'wechat') { // 阿里旺旺和微信用精确匹配 $socialQuery .= "cc.{$field}_1 = '" . $conn->real_escape_string($value) . "' OR " . "cc.{$field}_2 = '" . $conn->real_escape_string($value) . "' OR " . "cc.{$field}_3 = '" . $conn->real_escape_string($value) . "'"; } else { // Facebook和LinkedIn用模糊匹配 $socialQuery .= "cc.{$field}_1 LIKE '%" . $conn->real_escape_string($value) . "%' OR " . "cc.{$field}_2 LIKE '%" . $conn->real_escape_string($value) . "%' OR " . "cc.{$field}_3 LIKE '%" . $conn->real_escape_string($value) . "%'"; } $socialQuery .= ") LIMIT 1"; $socialResult = $conn->query($socialQuery); if ($socialResult && $socialResult->num_rows > 0) { $row = $socialResult->fetch_assoc(); $matchCustomerId = $row['id']; $matchCustomerCode = $row['cs_code']; $matchOwner = $row['cs_belong']; $matchAddTime = $row['cs_addtime']; $matchDetails = $label . "账号匹配"; // 不同社交媒体账号的可信度 switch ($field) { case 'alibaba': $matchScore = 0.85; break; case 'wechat': $matchScore = 0.85; break; case 'facebook': $matchScore = 0.80; break; case 'linkedin': $matchScore = 0.80; break; default: $matchScore = 0.75; } $duplicateFound = true; break; // 找到匹配就退出循环 } } } } // 4. 最后尝试全文检索 - 作为补充检测手段 if (!$duplicateFound) { // 准备全文检索字符串 $searchTerms = []; // 处理所有联系人信息用于检索 foreach ($contacts as $contact) { // 添加联系人名称 if (!empty($contact['contact_name'])) { $searchTerms[] = textUncode($contact['contact_name']); } // 所有联系方式的组合检索 $contactFields = [ 'tel', 'email', 'whatsapp', 'wechat', 'linkedin', 'facebook', 'alibaba' ]; foreach ($contactFields as $fieldType) { for ($i = 1; $i <= 3; $i++) { $field = $fieldType . '_' . $i; if (!empty($contact[$field])) { // 针对不同类型的联系方式进行不同清理 if ($fieldType == 'tel' || $fieldType == 'whatsapp') { $cleaned = preg_replace('/[^0-9]/', '', $contact[$field]); if (strlen($cleaned) > 5) { $searchTerms[] = $cleaned; } } else if ($fieldType == 'email') { $cleaned = strtolower(trim($contact[$field])); if (strpos($cleaned, '@') !== false) { $searchTerms[] = $cleaned; } } else { $searchTerms[] = trim($contact[$field]); } } } } } // 如果有搜索条件 if (!empty($searchTerms)) { // 创建MATCH AGAINST语句的词条 $searchStr = implode(' ', array_unique(array_filter($searchTerms))); // 确保搜索字符串不为空 if (!empty($searchStr)) { // 构建全文检索SQL $ftQuery = "SELECT c.id, c.cs_code, c.cs_belong, c.cs_addtime, MATCH( cc.tel_1, cc.tel_2, cc.tel_3, cc.email_1, cc.email_2, cc.email_3, cc.whatsapp_1, cc.whatsapp_2, cc.whatsapp_3, cc.wechat_1, cc.wechat_2, cc.wechat_3 ) AGAINST('" . $conn->real_escape_string($searchStr) . "' IN NATURAL LANGUAGE MODE) AS score FROM customer c JOIN customer_contact cc ON c.id = cc.customer_id WHERE c.id != " . $excludeId . " HAVING score > 0.7 ORDER BY score DESC LIMIT 1"; $ftResult = $conn->query($ftQuery); if(!($ftResult && $ftResult->num_rows > 0 )) { $ftQuery = "SELECT c.id, c.cs_code, c.cs_belong, c.cs_addtime, MATCH( cc.alibaba_1, cc.alibaba_2, cc.alibaba_3, cc.facebook_1, cc.facebook_2, cc.facebook_3, cc.linkedin_1, cc.linkedin_2, cc.linkedin_3) AGAINST('" . $conn->real_escape_string($searchStr) . "' IN NATURAL LANGUAGE MODE) AS score FROM customer c JOIN customer_contact cc ON c.id = cc.customer_id WHERE c.id != " . $excludeId . " HAVING score > 0.7 ORDER BY score DESC LIMIT 1"; $ftResult = $conn->query($ftQuery); } if ($ftResult && $ftResult->num_rows > 0) { $row = $ftResult->fetch_assoc(); $matchCustomerId = $row['id']; $matchCustomerCode = $row['cs_code']; $matchOwner = $row['cs_belong']; $matchAddTime = $row['cs_addtime']; $matchDetails = "全文检索相似度" . number_format($row['score'] * 100, 1) . "%"; $matchScore = $row['score']; $duplicateFound = true; } } } } // 如果找到重复客户,记录并提示 if ($duplicateFound) { // 获取客户所有者姓名 $ownerResult = $conn->query("SELECT em_user FROM employee WHERE id = " . $matchOwner); $ownerRow = $ownerResult->fetch_assoc(); $owner = textUncode($ownerRow['em_user']); // 确定谁先录入 if (strtotime($cs_addtime) > strtotime($matchAddTime)) { $tstr = "INSERT INTO logrecord (loginName, loginIp, loginTime, loginAct) VALUES ('" . $_SESSION['employee_name'] . "', '" . getIp() . "', '" . date('Y-m-d H:i:s') . "', '" . $_SESSION['employee_name'] . "编辑客户\"" . $cs_code . "\",该客户与\"" . textUncode($matchCustomerCode) . "\"存在重复,
匹配类型:" . $matchDetails . "
客户由:" . $owner . $matchAddTime . "首次录入')"; } else { $tstr = "INSERT INTO logrecord (loginName, loginIp, loginTime, loginAct) VALUES ('" . $_SESSION['employee_name'] . "', '" . getIp() . "', '" . date('Y-m-d H:i:s') . "', '" . $_SESSION['employee_name'] . "编辑客户\"" . $cs_code . "\",该客户与\"" . textUncode($matchCustomerCode) . "\"存在重复,
匹配类型:" . $matchDetails . "
客户由:" . $_SESSION['employee_name'] . $cs_addtime . "首次录入')"; } $conn->query($tstr); echo ""; exit; } } } // Save or update customer data if ($act == "editSave" || $allowedit == 1) { $hrefstr = "/customers.php?Keys=" . $keys . "&fliterBusiness=" . $fliterBusiness . "&fliterDeal=" . $fliterDeal . "&Page=" . $page; // 更新客户基本信息 $updateSql = "UPDATE customer SET cs_code='" . $conn->real_escape_string($cs_code) . "', cs_company='" . $conn->real_escape_string($cs_company) . "', cs_country=" . $cs_country . ", cs_from=" . $cs_from . ", cs_address='" . $conn->real_escape_string($cs_address) . "', cs_updatetime='" . $cs_updatetime . "', cs_belong=" . $cs_belong . ", cs_belongclient=" . $cs_belongClient . ", cs_state=" . $cs_state . ", cs_deal=" . $cs_deal . ", cs_note='" . $conn->real_escape_string($cs_note) . "'"; // 处理cs_dealdate if ($cs_deal == 3) { $updateSql .= ", cs_dealdate = CASE WHEN cs_dealdate IS NULL THEN NOW() ELSE cs_dealdate END"; } $updateSql .= " WHERE id=" . intval($id); $conn->query($updateSql); // 处理业务类型 - 先删除已有的业务类型 $conn->query("DELETE FROM customer_business_type WHERE customer_id = " . intval($id)); // 添加新的业务类型 if (!empty($cs_type) && is_array($cs_type)) { foreach ($cs_type as $type_id) { $type_id = intval($type_id); if ($type_id > 0) { $conn->query("INSERT INTO customer_business_type (customer_id, business_type_id) VALUES (" . intval($id) . ", " . $type_id . ")"); } } } // 处理联系人信息 - 首先删除已有的不在提交列表中的联系人 $existingContactIds = []; foreach ($contacts as $contact) { if (!empty($contact['id'])) { $existingContactIds[] = (int)$contact['id']; } } if (!empty($existingContactIds)) { $idsToKeep = implode(',', $existingContactIds); $deleteContactsSql = "DELETE FROM customer_contact WHERE customer_id = " . intval($id) . " AND id NOT IN (" . $idsToKeep . ")"; } else { $deleteContactsSql = "DELETE FROM customer_contact WHERE customer_id = " . intval($id); } $conn->query($deleteContactsSql); // 处理联系人信息 - 更新或添加联系人 foreach ($contacts as $contact) { $contact_id = !empty($contact['id']) ? (int)$contact['id'] : 0; $contact_name = textEncode($contact['contact_name'] ?? ''); // 准备SQL字段和值 $fields = ['contact_name']; $values = ["'" . $conn->real_escape_string($contact_name) . "'"]; $updates = ["contact_name = '" . $conn->real_escape_string($contact_name) . "'"]; // 处理所有联系方式类型 $methodTypes = ['tel', 'email', 'whatsapp', 'wechat', 'linkedin', 'facebook', 'alibaba']; foreach ($methodTypes as $type) { for ($i = 1; $i <= 3; $i++) { $field = $type . '_' . $i; $format_field = $field . '_format'; $bu_field = $field . '_bu'; $value = textEncode($contact[$field] ?? ''); $format_value = ($type == 'tel' || $type == 'whatsapp') ? numFormat($value) : ''; $bu_value = textEncode($contact[$bu_field] ?? $value); // 添加字段名 $fields[] = $field; $fields[] = $bu_field; if ($type == 'tel' || $type == 'whatsapp') { $fields[] = $format_field; } // 添加值 $values[] = "'" . $conn->real_escape_string($value) . "'"; $values[] = "'" . $conn->real_escape_string($bu_value) . "'"; if ($type == 'tel' || $type == 'whatsapp') { $values[] = "'" . $conn->real_escape_string($format_value) . "'"; } // 添加更新语句 $updates[] = $field . " = '" . $conn->real_escape_string($value) . "'"; $updates[] = $bu_field . " = '" . $conn->real_escape_string($bu_value) . "'"; if ($type == 'tel' || $type == 'whatsapp') { $updates[] = $format_field . " = '" . $conn->real_escape_string($format_value) . "'"; } } } if ($contact_id > 0) { // 更新已有联系人 $updateContactSql = "UPDATE customer_contact SET " . implode(", ", $updates) . ", updated_at = NOW() " . "WHERE id = " . $contact_id . " AND customer_id = " . intval($id); $conn->query($updateContactSql); } else { // 添加新联系人 $insertContactSql = "INSERT INTO customer_contact (" . implode(", ", $fields) . ", customer_id, created_at, updated_at) VALUES (" . implode(", ", $values) . ", " . intval($id) . ", NOW(), NOW())"; $conn->query($insertContactSql); } } // Update tags $conn->query("DELETE FROM tagtable WHERE customerId = " . intval($id)); foreach ($mytag as $tag) { if (!empty(trim($tag))) { $tagSql = "INSERT INTO tagtable (tagName, employeeId, customerId) VALUES ('" . $conn->real_escape_string($tag) . "', " . intval($_SESSION['employee_id']) . ", " . intval($id) . ")"; $conn->query($tagSql); } } echo ""; } else { // Insert new customer record $insertSql = "INSERT INTO customer ( cs_code, cs_company, cs_country, cs_from, cs_address, cs_addtime, cs_updatetime, cs_belong, cs_belongClient, cs_state, cs_deal, cs_note, cs_chain, is_silent, cs_dealdate ) VALUES ( '" . $conn->real_escape_string($cs_code) . "', '" . $conn->real_escape_string($cs_company) . "', " . $cs_country . ", " . $cs_from . ", '" . $conn->real_escape_string($cs_address) . "', NOW(), NOW(), " . $cs_belong . ", " . $cs_belongClient . ", " . $cs_state . ", " . $cs_deal . ", '" . $conn->real_escape_string($cs_note) . "', " . $cs_belong . ", 0, " . ($cs_deal == 3 ? "NOW()" : "NULL") . " )"; $conn->query($insertSql); $new_customer_id = $conn->insert_id; // Insert business types for new customer if ($new_customer_id > 0 && !empty($cs_type) && is_array($cs_type)) { foreach ($cs_type as $type_id) { $type_id = intval($type_id); if ($type_id > 0) { $conn->query("INSERT INTO customer_business_type (customer_id, business_type_id) VALUES (" . $new_customer_id . ", " . $type_id . ")"); } } } // Insert contact information for all contacts if ($new_customer_id > 0) { foreach ($contacts as $contact) { $contact_name = textEncode($contact['contact_name'] ?? ''); // 准备SQL字段和值 $fields = ['contact_name']; $values = ["'" . $conn->real_escape_string($contact_name) . "'"]; // 处理所有联系方式类型 $methodTypes = ['tel', 'email', 'whatsapp', 'wechat', 'linkedin', 'facebook', 'alibaba']; foreach ($methodTypes as $type) { for ($i = 1; $i <= 3; $i++) { $field = $type . '_' . $i; $format_field = $field . '_format'; $bu_field = $field . '_bu'; $value = textEncode($contact[$field] ?? ''); $format_value = ($type == 'tel' || $type == 'whatsapp') ? numFormat($value) : ''; $bu_value = textEncode($contact[$bu_field] ?? $value); // 添加字段名 $fields[] = $field; $fields[] = $bu_field; if ($type == 'tel' || $type == 'whatsapp') { $fields[] = $format_field; } // 添加值 $values[] = "'" . $conn->real_escape_string($value) . "'"; $values[] = "'" . $conn->real_escape_string($bu_value) . "'"; if ($type == 'tel' || $type == 'whatsapp') { $values[] = "'" . $conn->real_escape_string($format_value) . "'"; } } } // 添加新联系人 $insertContactSql = "INSERT INTO customer_contact (" . implode(", ", $fields) . ", customer_id, created_at, updated_at) VALUES (" . implode(", ", $values) . ", " . $new_customer_id . ", NOW(), NOW())"; $conn->query($insertContactSql); } // Save tags for new customer foreach ($mytag as $tag) { if (!empty(trim($tag))) { $tagSql = "INSERT INTO tagtable (tagName, employeeId, customerId) VALUES ('" . $conn->real_escape_string($tag) . "', " . intval($_SESSION['employee_id']) . ", " . intval($new_customer_id) . ")"; $conn->query($tagSql); } } } echo ""; } ?>