1
誰でもこの問題をお手伝いできますか?私は非常に多くの異なったことを試みました、そして、私はまだこのエラーを得ています。エラーは、cmd.ExecuteNonQuery()行を指しています。私は100万回の挿入文字列をチェックしましたが、何が問題なのか分かりません。ありがとう!あなたは[]であなたの列を置くべきOleDbException(x80040E14):文への挿入で構文エラーが発生しました
OleDbConnection myConnection = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + targetPath);
try
{
for (int i = 0; i < listOfDBTables.Count; i++)
{
for (int j = 1; j < listOfDBTables[i].Rows.Count; j++)
//Don't include the header
{
OleDbCommand cmd = new OleDbCommand("INSERT INTO POP(Global Customer, Sold To #, Material #, Material Description, Customer ID, Customer Name, City, State, Country, Market Code, Unit Cost, Invoice Date, [Month], Quantity, UoM, KG, [Year]) Values (@globCust,@soldToNum,@matNum,@matDesc,@custID,@custName,@city,@state,@country,@mktCode,@cost,@invDate,@month,@quantity,@uom,@kg,@year)", myConnection);
cmd.Parameters.AddWithValue("@globCust", listOfDBTables[i].Rows[j][0].ToString());
cmd.Parameters.AddWithValue("@soldToNum", listOfDBTables[i].Rows[j][1].ToString());
cmd.Parameters.AddWithValue("@matNum", listOfDBTables[i].Rows[j][2].ToString());
cmd.Parameters.AddWithValue("@matDesc", listOfDBTables[i].Rows[j][3].ToString());
cmd.Parameters.AddWithValue("@custID", listOfDBTables[i].Rows[j][4].ToString());
cmd.Parameters.AddWithValue("@custName", listOfDBTables[i].Rows[j][5].ToString());
cmd.Parameters.AddWithValue("@city", listOfDBTables[i].Rows[j][6].ToString());
cmd.Parameters.AddWithValue("@state", listOfDBTables[i].Rows[j][7].ToString());
cmd.Parameters.AddWithValue("@country", listOfDBTables[i].Rows[j][8].ToString());
cmd.Parameters.AddWithValue("@mktCode", listOfDBTables[i].Rows[j][9].ToString());
cmd.Parameters.AddWithValue("@cost", listOfDBTables[i].Rows[j][10].ToString());
cmd.Parameters.AddWithValue("@invDate", listOfDBTables[i].Rows[j][11].ToString());
cmd.Parameters.AddWithValue("@month", listOfDBTables[i].Rows[j][12].ToString());
cmd.Parameters.AddWithValue("@quantity", listOfDBTables[i].Rows[j][13].ToString());
cmd.Parameters.AddWithValue("@uom", listOfDBTables[i].Rows[j][14].ToString());
cmd.Parameters.AddWithValue("@kg", listOfDBTables[i].Rows[j][15].ToString());
cmd.Parameters.AddWithValue("@year", listOfDBTables[i].Rows[j][16].ToString());
myConnection.Open();
cmd.ExecuteNonQuery();
}
}
}
catch(Exception ex)
{
MessageBox.Show(ex.ToString());
}
finally
{
myConnection.Close();
}
に販売します。例:[Global Customer] –
プロバイダは名前のないパラメータ( '? 'を使用)のみを扱うことがあります – SLaks
まだいくつかのエラーが発生していますが、進歩しているようです。角括弧内のすべての列名を折り返すと、そのトリックが完了した可能性があります。私はこれを解決すれば私は再び投稿します。ありがとう@MarcusH –