0
LOAD DATA INFILEコマンドを使用して特定のフィールドをスキップする方法を教えてください。SQL LOAD DATA INFILE質問
私は、次の表を考えてみましょう:
CREATE TABLE stuff (
id INT UNSIGNED AUTO_INCREMENT NOT NULL,
name CHAR(64) NOT NULL,
junk CHAR(64) NOT NULL,
a ENUM('N','Y') NOT NULL DEFAULT 'N',
PRIMARY KEY (id)
);
そして、私のファイル:
,name1,junk1,
,name2,junk2,
,name3,junk3,Y
声明ん:
LOAD DATA INFILE 'myfile' INTO TABLE stuff FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n';
は自動的に自動インクリメントをスキップし、それに対処正しく?適切にすべてを処理するようだが、これは次の警告を生成します。
Warning (Code 1366): Incorrect integer value: '' for column 'id' at row 1
Warning (Code 1265): Data truncated for column 'a' at row 1
Warning (Code 1366): Incorrect integer value: '' for column 'id' at row 2
Warning (Code 1366): Incorrect integer value: '' for column 'id' at row 3
Warning (Code 1265): Data truncated for column 'a' at row 3
Warning (Code 1366): Incorrect integer value: '' for column 'id' at row 4
正しく入力データを先頭にカンマがありません取り除きます。