ไม่สามารถนำเข้าฐานข้อมูล SQL ที่เข้ารหัส UTF-8 ในเครื่องบน Mac


23

ฉันกำลังนำเข้าฐานข้อมูล SQL ที่เข้ารหัส UTF-8 ที่ได้รับการยืนยันไปยัง Sequel Pro บน Mac และได้โยนข้อผิดพลาดนี้ไปครึ่งทางแล้ว:

เกิดข้อผิดพลาดขณะอ่านไฟล์เนื่องจากไม่สามารถอ่านได้ในการเข้ารหัสที่คุณเลือก (ตรวจหาอัตโนมัติ - 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 `******`
--

ข้อความใดทำให้เกิดปัญหา
Rick James

ไม่ได้พูด แต่ฉันเดาว่าตัวแบ่งบรรทัดของ windows ถูกเข้ารหัส
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) ที่ไม่ได้ให้ฉันนำเข้าตอนแรก
Douglas.Sesar

1
ขอบคุณสิ่งนี้ใช้ได้กับการทิ้ง MySQL ที่สร้างขึ้นบน CentOS
Alex

ฉันยืนยันว่าใช้งานได้กับ MacOS High Sierra 10.13.6 Thanks @liangzan
Ahmad Mushtaq

ใช้งานได้กับ Sequel Pro (ทุกคืน) ใน Mojave เช่นกัน
Urs

สิ่งนี้ทำงานได้อย่างถูกต้องสำหรับการถ่ายโอนข้อมูล MySQL ที่มาจาก Linux / Mysql และจำเป็นต้องนำเข้าผ่าน SSH ไปยังฐานข้อมูล MariaDB 10 ขอบคุณ
HongPong
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.