OleDbConnection - 并非所有信息都被传递

时间:2016-06-16 15:42:42

标签: c# oledbconnection oledbcommand executenonquery

我正在尝试将一些信息传递给Access数据库,但我不确定我是否正确使用ExecuteNonQuery()。以下是我使用的代码:

public void WriteToDB(string connStr, string tblName)
    {
        string[] accounts = { "@ID", "@Date", "@Line Item", "@Ranking Item", "@Item Attribute", "@Current_Period_Ranking(b)" };

        OleDbConnection conn = new OleDbConnection(connStr);
        conn.Open();
        OleDbCommand CmdSQL = new OleDbCommand(string.Format("Insert into [{0}] ([ID], [Date], [Line Item], [Ranking Item], [Ranking]) VALUES(?,?,?,?,?)",tblName),conn);
        CmdSQL.Parameters.AddWithValue("@ID", 1);
        CmdSQL.Parameters.AddWithValue("@Date", "6/20/2016");
        CmdSQL.Parameters.AddWithValue("@Line Item", this.ItemName);
        CmdSQL.Parameters.AddWithValue("@Ranking Item", "Ranking");
        CmdSQL.Parameters.AddWithValue("@Ranking", this.Rank.GetLineItem(3));
        CmdSQL.ExecuteNonQuery();
        CmdSQL.Parameters.AddWithValue("@ID", 2);
        CmdSQL.Parameters.AddWithValue("@Date", "6/20/2016");
        CmdSQL.Parameters.AddWithValue("@Line Item", this.ItemName);
        CmdSQL.Parameters.AddWithValue("@Ranking Item", "Price");
        CmdSQL.Parameters.AddWithValue("@Ranking", this.Price);
        CmdSQL.ExecuteNonQuery();
        CmdSQL.Parameters.AddWithValue("@ID", 3);
        CmdSQL.Parameters.AddWithValue("@Date", "6/20/2016");
        CmdSQL.Parameters.AddWithValue("@Line Item", this.ItemName);
        CmdSQL.Parameters.AddWithValue("@Ranking Item", "Pounds");
        CmdSQL.Parameters.AddWithValue("@Ranking", this.Pounds);
        CmdSQL.ExecuteNonQuery();
        CmdSQL.Parameters.AddWithValue("@ID", 4);
        CmdSQL.Parameters.AddWithValue("@Date", "6/20/2016");
        CmdSQL.Parameters.AddWithValue("@Line Item", this.ItemName);
        CmdSQL.Parameters.AddWithValue("@Ranking Item", "Opportunity");
        CmdSQL.Parameters.AddWithValue("@Ranking", this.Opportunity);
        CmdSQL.ExecuteNonQuery();
    }

当我运行这段代码时,Access DB只显示1。

1 个答案:

答案 0 :(得分:3)

由于您使用相同的命令,因此必须在以后清除参数:

CmdSQL.ExecuteNonQuery();
CmdSQL.Parameters.Clear();
CmdSQL.Parameters.AddWithValue("@ID", 4);
....

在旁注中,日期应该是数据库中的日期,而不是字符串。如果你有一堆具有相同结构的表,你的数据库看起来有问题。为什么不只是一个表和一个区域来区分它是什么类型的行。它会使您的查询更容易。将这些一次性数据库对象放在使用块中也是非常常见和有益的。