我读取和更新Access数据库时出现的奇怪现象

时间:2013-06-04 12:11:45

标签: c# web-services ms-access

我有一个Access数据库,其字段名为[TermNum](自动编号)。

我尝试在Access数据库中注册终端(通过我的WebService C#),如下所示:

using (Conn = new OleDbConnection(Connect))
{
    Conn.Open();

    SQL = "select TermNum from TermNumTbl where DeviceID = '" + DeviceID + "'";
    dsView = new DataSet();
    adp = new OleDbDataAdapter(SQL, Conn);
    adp.Fill(dsView, "TermNumTbl");
    adp.Dispose();

    try
    {
        iTermNumTmp = Convert.ToInt32(dsView.Tables[0].Rows.Count);
    }
    catch
    {
        iTermNumTmp = 0;
    }

    if (iTermNumTmp >= 1) 
    {
        return (Convert.ToInt32(dsView.Tables[0].Rows[0][0].ToString().Trim()));
    }
    else
    {
        int ID;
        SQL = "insert into TermNumTbl (DeviceID,IP) values (@DeviceID,@DeviceIP)";

        using (OleDbCommand Cmd4 = new OleDbCommand(SQL, Conn))
        {
            Cmd4.Parameters.AddWithValue("@DeviceID", DeviceID);
            Cmd4.Parameters.AddWithValue("@DeviceIP", DeviceIP);
            Cmd4.ExecuteNonQuery();

            SQL = "Select @@Identity";
            Cmd4.CommandText = SQL;
            ID = (int)Cmd4.ExecuteScalar();
        }
        return ID;
    }
}

如果终端存在=返回他的号码

如果终端不存在=将他的号码插入数据库并返回此号码

问题是,有时它不起作用,我收到此错误:

  

名为“TermNumTbl”的DataTable已属于此DataSet

1 个答案:

答案 0 :(得分:1)

从您的代码中可以看出,您已经在方法之外的某个地方定义了dsView(作为类成员?)。您正尝试将同一个表选择到同一数据集中。根据需要将数据集定义为本地对象。变化:

dsView = new DataSet();

为:

DataSet dsView = new DataSet();