Не удается локально импортировать базу данных SQL в кодировке UTF-8 на Mac

23

Я импортировал подтвержденную базу данных SQL в кодировке UTF-8 в Sequel Pro на Mac и получил эту ошибку на полпути:

Произошла ошибка при чтении файла, так как он не мог быть прочитан в выбранной вами кодировке (Autodetect - Unicode (UTF-8)).

Всего было выполнено 1273 запроса.

Это из-за того, что файл базы данных был изначально с машины с Windows, и в нем разбиты строки?

Я предполагаю, что получу эту ошибку, даже если я попытался отправить ту же самую базу данных через передачу файла на сервер, так как я могу исправить это кодирование?

-- MySQL dump 10.13  Distrib 5.5.40-36.1, for Linux (x86_64)
--
-- Host: localhost    Database: *****
-- ------------------------------------------------------
-- Server version   5.5.40-36.1-log

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--
-- Table structure for table `******`
--
smokerockspunchcops
источник
Какой текст вызвал проблему?
Рик Джеймс
не сказал, но я думаю, что это зашифрованная строка в Windows
smokerockspunchcops
Сохранение файла в блокноте имеет опцию кодирования в нижней части. Откройте файл в блокноте в Windows и сохраните его в формате utf-8, а затем попробуйте загрузить его в MySQL
Nawaz Sohail
Значит файл не настоящий utf-8? Если я на Mac, я могу сделать то же самое с помощью программы просмотра текста по умолчанию, чтобы это исправить?
smokerockspunchcops
Как писал выше Наваз, откройте файл в текстовом редакторе (я использовал TextWrangler на Mac) и сохраните в формате utf-8.
Jojje

Ответы:

52

На основании этого сообщения в блоге

http://ilikekillnerds.com/2014/08/fixing-sequel-pro-sql-encoding-error-for-imported-sql-files/

При импорте дампа базы данных вам нужно выбрать Western (Mac OS Roman) в качестве формата кодировки для файла, который нужно импортировать без проблем.

liangzan
источник
1
Кто-нибудь знает, почему это работает? Я действительно хотел бы знать, какая проблема существовала с UTF-8 (или какая проблема с Windows), которая не позволяла мне импортировать изначально.
Douglas.Sesar
1
Спасибо, это также работает для дампов MySQL, которые генерируются в CentOS.
Алекс
Я подтверждаю, что это работает на MacOS High Sierra 10.13.6. спасибо @liangzan
Ахмад Муштак
Это работает и с Sequel Pro (Nightly) в Мохаве.
Urs
Это работало правильно для дампа MySQL, который возник в Linux / Mysql и должен был быть импортирован через SSH в базу данных MariaDB 10. Спасибо.
Гонконг