使用Windows Server 2003,MySQL 5.1.23,MySQL .NET Connector 6.2.2
我正在尝试使用MySQLBulkLoader类来读取固定宽度的文本文件。这个类的摘录Load方法是:
string sql = BuildSqlCommand();
MySqlCommand cmd = new MySqlCommand(sql, Connection);
cmd.CommandTimeout = 10 * 60;// Timeout;
cmd.ExecuteNonQuery();
'BuildSqlCommand'创建的字符串是:
LOAD DATA LOCAL INFILE 'c:/M/D/ALLDATA_0.TXT' INTO TABLE dk.tk
FIELDS TERMINATED BY '' LINES TERMINATED BY '\n'
当程序启动'ExecuteNonQuery'时,会发生以下错误:
(消息)命令执行期间遇到致命错误。 (来源)MySql.Data (内部异常消息)尝试读取结果集时遇到致命错误。
ExecuteNonQuery是否有任何已知限制?文本文件大小为290MB。
答案 0 :(得分:2)
经过多次尝试后,看起来错误与LOAD DATA INFILE语句的语法和MySQL Bulk Loader的工作方式有关。我最终完全忽略了MySQL Bulk Loader类,因为BuildSQLCommand方法返回的结果不起作用。 BulkLoader的问题在于它似乎需要以逗号分隔的文件,其中我的文件是固定宽度而没有字段分隔符。
以下代码示例适用于导入固定宽度文件 - 设置表字段大小以将文件切片到适当的字段中。
string sql = @"load data infile 'c:/myfolder/Data/" + aFile.Name
+ "' ignore into table t_data fields terminated by '' enclosed by '' lines terminated by '\n'";
MySqlCommand cmd = new MySqlCommand(sql, conn);
cmd.CommandTimeout = Timeout;
cmd.ExecuteNonQuery();
我的超时值设置为0.