从MySQL ExecuteNonQuery获得“致命错误”?

时间:2010-09-01 20:02:10

标签: c# .net mysql

使用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。

1 个答案:

答案 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.