当我读取和更新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'的数据表已经属于这个数据集
似乎从你的代码,你已经定义了dsView方法之外的某个地方(作为类成员也许?)。您正在尝试在相同数据集中选择相同的表。根据需要将数据集定义为本地对象。变化:
dsView = new DataSet();
:
DataSet dsView = new DataSet();