62

11列のCSVファイルがあり、9列のMySQLテーブルがあります。

CSVファイルは次のようになります。

col1, col2, col3, col4, col5, col6, col7, col8, col9, col10, col11

MySQLテーブルは次のようになります。

col1, col2, col3, col4, col5, col6, col7, col8, col9

CSVファイルの列1〜8をMySQLテーブルの最初の8列に直接マップする必要があります。次に、CSVファイルの次の2列をスキップして、CSVファイルの列11をMySQLテーブルの列9にマップする必要があります。

現在、次のSQLコマンドを使用しています。

LOAD DATA LOCAL INFILE 'filename.csv' INTO TABLE my_table
FIELDS TERMINATED BY ','
ENCLOSED BY ''
LINES TERMINATED BY '\n'

ただし、上記のコードは、CSVファイルの最初の9列をMySQLテーブルの9列にマップします。

4

4 に答える 4

97

Mysqlドキュメントから:

入力値をユーザー変数に割り当て、変数をテーブル列に割り当てないことで、入力値を破棄することもできます。

LOAD DATA INFILE 'file.txt'  
INTO TABLE t1 (column1, @dummy, column2, @dummy, column3);
于 2010-01-26T11:42:06.200 に答える
4

step1.awkに対処します。

cat file.txt |awk '{print $1,$2,$5...}'>new_file.txt

step2.mysql にロードします。

load data local infile 'new_file' into table t1(...)

以下の方法は簡単ですが、下位バージョンの mysql では許可されていません。

LOAD DATA INFILE 'file.txt'  
INTO TABLE t1 (column1, @dummy, column2, @dummy, column3);
于 2014-01-22T07:01:20.483 に答える
-1

@ディーミ

を無視する唯一の方法@dummyは、フィールドのデフォルトを に設定することAUTO INCREMENTです。したがって、フィールドをスキップして、次のようにコーディングできます。

LOAD DATA INFILE 'file.txt'  
INTO TABLE t1 (column2, column3, column4, column5);

column1// フィールド名がデフォルトで に設定されていると仮定しAUTO INCREMENTます。

于 2014-11-13T06:04:52.207 に答える
-1

コードにはもう1つ変更があると思います:

次の SQL コマンド:

LOAD DATA LOCAL INFILE 'filename.csv' INTO TABLE my_table
FIELDS TERMINATED BY ','
ENCLOSED BY ''
LINES TERMINATED BY '\n'

- データ切り捨てエラーが発生する可能性があります。

したがって、LINES TERMINATED BY '\r\n'代わりに使用することをお勧めしますLINES TERMINATED BY '\n'

SOコードは次のようになります。

LOAD DATA LOCAL INFILE 'filename.csv' INTO TABLE my_table
FIELDS TERMINATED BY ','
ENCLOSED BY ''
LINES TERMINATED BY '\r\n'
于 2014-11-13T06:10:17.970 に答える