Files
crm.clientright.ru/fix_all_collation_utf8mb3.php
Fedor 840acca51a feat(documents): дедупликация documents_meta и исправление field_label
- Исправлен N8N_CODE_PROCESS_UPLOADED_FILES_FIXED.js: использовать uploads_field_labels[0] вместо [grp]
- Создан SQL_CLAIMSAVE_FIXED_NEW_FLOW_DEDUP.sql с дедупликацией documents_meta
- Создан SQL_CLEANUP_DOCUMENTS_META_DUPLICATES.sql для очистки существующих дубликатов
- Создан полный уникальный индекс idx_document_texts_hash_unique на document_texts(file_hash)
- Добавлен SESSION_LOG_2025-11-28_documents_dedup.md с описанием всех изменений

Fixes:
- field_label теперь корректно отображает 'Переписка' вместо 'group-2'
- documents_meta не накапливает дубликаты при повторных сохранениях
- ON CONFLICT (file_hash) теперь работает для document_texts
2025-11-28 18:16:53 +03:00

133 lines
4.3 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
/**
* Исправление всех таблиц с utf8mb3_bin на utf8mb4_general_ci
*/
$dbHost = '192.168.128.3';
$dbUser = 'nextcloud';
$dbPass = 'nextcloud_password';
$dbName = 'nextcloud';
try {
$pdo = new PDO(
"mysql:host=$dbHost;dbname=$dbName;charset=utf8mb4",
$dbUser,
$dbPass,
[PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION]
);
echo "=== ИСПРАВЛЕНИЕ ВСЕХ ТАБЛИЦ С utf8mb3_bin ===\n\n";
// Находим все колонки с utf8mb3_bin
$query = "
SELECT
TABLE_NAME,
COLUMN_NAME,
DATA_TYPE,
COLUMN_TYPE,
CHARACTER_SET_NAME,
COLLATION_NAME
FROM
INFORMATION_SCHEMA.COLUMNS
WHERE
TABLE_SCHEMA = ?
AND TABLE_NAME LIKE 'oc_%'
AND COLLATION_NAME LIKE '%utf8mb3%'
ORDER BY TABLE_NAME, COLUMN_NAME
";
$stmt = $pdo->prepare($query);
$stmt->execute([$dbName]);
$columns = $stmt->fetchAll(PDO::FETCH_ASSOC);
if (empty($columns)) {
echo "Все колонки уже имеют правильную collation!\n";
exit(0);
}
echo "Найдено колонок с utf8mb3: " . count($columns) . "\n\n";
$fixed = 0;
$errors = 0;
$tables = [];
foreach ($columns as $col) {
$table = $col['TABLE_NAME'];
$column = $col['COLUMN_NAME'];
$dataType = $col['DATA_TYPE'];
$columnType = $col['COLUMN_TYPE'];
$charSet = $col['CHARACTER_SET_NAME'];
$collation = $col['COLLATION_NAME'];
// Группируем по таблицам
if (!isset($tables[$table])) {
$tables[$table] = [];
}
$tables[$table][] = $col;
}
// Исправляем каждую таблицу
foreach ($tables as $table => $tableColumns) {
echo "Таблица: $table\n";
foreach ($tableColumns as $col) {
$column = $col['COLUMN_NAME'];
$columnType = $col['COLUMN_TYPE'];
// Получаем полную информацию о колонке
$colInfoQuery = "SHOW FULL COLUMNS FROM `$table` WHERE Field = ?";
$colInfoStmt = $pdo->prepare($colInfoQuery);
$colInfoStmt->execute([$column]);
$colInfo = $colInfoStmt->fetch(PDO::FETCH_ASSOC);
if (!$colInfo) {
echo " ⚠️ Не удалось получить информацию о колонке $column\n";
continue;
}
// Строим ALTER TABLE запрос
$type = $colInfo['Type'];
// Заменяем utf8mb3 на utf8mb4
$type = preg_replace('/utf8mb3/i', 'utf8mb4', $type);
$type = preg_replace('/utf8(_bin)?/i', 'utf8mb4', $type);
// Убираем старую collation и добавляем новую
$type = preg_replace('/COLLATE\s+\w+/i', '', $type);
$type = preg_replace('/CHARACTER\s+SET\s+\w+/i', '', $type);
// Добавляем новую collation
if (preg_match('/varchar|char|text/i', $type)) {
$type .= ' CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci';
}
$null = $colInfo['Null'] === 'YES' ? 'NULL' : 'NOT NULL';
$default = '';
if ($colInfo['Default'] !== null) {
$default = "DEFAULT '" . addslashes($colInfo['Default']) . "'";
}
$extra = $colInfo['Extra'] ?: '';
$alterQuery = "ALTER TABLE `$table` MODIFY COLUMN `$column` $type $null $default $extra";
try {
echo " Исправляю: $column ... ";
$pdo->exec($alterQuery);
echo "\n";
$fixed++;
} catch (PDOException $e) {
echo "❌ Ошибка: " . $e->getMessage() . "\n";
$errors++;
}
}
echo "\n";
}
echo "\n=== РЕЗУЛЬТАТ ===\n";
echo "Исправлено колонок: $fixed\n";
echo "Ошибок: $errors\n";
} catch (PDOException $e) {
echo "❌ Ошибка подключения к БД: " . $e->getMessage() . "\n";
exit(1);
}