当我读取和更新Access数据库时,出现了一个奇怪的现象

本文关键字:一个 更新 读取 Access 数据库 | 更新日期: 2023-09-27 18:16:46

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

我尝试在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'的数据表已经属于这个数据集

当我读取和更新Access数据库时,出现了一个奇怪的现象

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

dsView = new DataSet();

:

DataSet dsView = new DataSet();