Неможливо локально імпортувати кодовану UTF-8 базу даних SQL на 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 і збережіть його у форматі utf-8, а потім спробуйте завантажити його в MySQL
Nawaz Sohail

Отже, файл не справжній utf-8? Якщо я перебуваю на комп'ютері Mac, я можу зробити те саме, що і для перегляду тексту за замовчуванням, щоб виправити це?
smokerockspunchcops

Як Nawaz писав вище, відкрийте файл у текстовому редакторі (я використовував 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) як формат кодування для файлу, який потрібно імпортувати без проблем.


1
Хтось знає, чому це працює? Мені дуже хотілося б знати, яка проблема існувала з UTF-8 (або яка проблема з Windows), що не дозволило мені імпортувати спочатку.
Дуглас.Сесар

1
Дякую, це також працює для дампів MySQL, які генеруються на CentOS.
Олексій

Я підтверджую, що це працює на MacOS High Sierra 10.13.6. дякую @liangzan
Ахмад Муштак

Це працює з Sequel Pro (Nightly) також на Mojave
Urs

Це працювало правильно для дампу MySQL, який виник на Linux / Mysql і його потрібно було імпортувати через SSH до бази даних MariaDB 10. Спасибі.
HongPong
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.