2017-01-29 15 views
0

大きなテーブル(iTunes EPF)を読み込むためにLOAD DATA INFILEを使用しています。LOAD DATA INFILE:無効なut8mb4文字列

ただし、インポートがこのエラーで失敗します。

string(52) "Invalid utf8mb4 character string: 'אל נא תלך'" 

テーブルは次のように作成されます。

CREATE TABLE `song-tmp` (
    `song_id` int(11) NOT NULL DEFAULT '0', 
    `name` varchar(1000) DEFAULT NULL, 
    `title_version` varchar(1000) DEFAULT NULL, 
    `artist_display_name` varchar(1000) DEFAULT NULL, 
    PRIMARY KEY (`song_id`) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4; 

は、これは私が使用しているインポートクエリです:

LOAD DATA LOCAL INFILE '/path/to/file' INTO TABLE `song-tmp` 
    CHARACTER SET utf8mb4 
    FIELDS TERMINATED BY X'01' 
    LINES TERMINATED BY X'020a' 
    (@export_date, song_id, name, title_version, @search_terms, @parental_advisory_id, artist_display_name, @collection_display_name, @view_url, @original_release_date, @itunes_release_date, @track_length, @copyright, @p_line, @preview_url, @preview_length) 
+2

いいね。 'LOAD'文の前に' SET NAMES utf8mb4; 'を実行してみてください。 –

+0

@RickJamesありがとう!解決される。 – guidev

答えて

0

リックジェームズが示唆したように、LOADの文の前にSET NAMES utf8mb4;を実行すると、このトリックが実行されました。

関連する問題