无法在Mac上本地导入UTF-8编码的SQL数据库


23

我将确认的UTF-8编码的SQL数据库导入Mac上的Sequel Pro,并在中途抛出此错误:

读取文件时发生错误,因为无法以您选择的编码(自动检测-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 `******`
--

什么文字引起了问题?
里克·詹姆斯

没有说,但是我猜是Windows编码的换行符
smokerockspunchcops 2015年

将文件保存在记事本中的确在底部具有编码选项。在Windows上的记事本中打开文件并将其保存为utf-8格式,然后尝试将其加载到MySQL中
Nawaz Sohail 2015年

因此,该文件不是真正的utf-8吗?如果我使用的是Mac,我可以使用默认的文本查看器来修复该问题吗?
smokerockspunchcops

正如Nawaz在上面所述,请在文本编辑器中打开文件(我在Mac上使用TextWrangler),然后将其重新保存为utf-8格式。
Jojje

Answers:


52

根据这篇博客文章

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

导入数据库转储时,需要选择Western(Mac OS Roman)作为文件导入的编码格式,而不会出现问题。


1
有谁知道这为什么起作用?我真的很想知道UTF-8存在什么问题(或Windows存在什么问题),这些问题使我最初无法导入。
道格拉斯·塞萨尔(Douglas.Sesar),

1
谢谢,这也适用于在CentOS上生成的MySQL转储。
亚历克斯(Alex)

我确认这可以在MacOS High Sierra 10.13.6上使用。感谢@liangzan
Ahmad Mushtaq

这也适用于Mojave上的Sequel Pro(Nightly)
Urs

对于源自Linux / Mysql且需要通过SSH导入到MariaDB 10数据库的MySQL转储,此方法正常工作。谢谢。
HongPong
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.