问题描述
- C#删除问题,会把两条数据同时删除
-
我有一张表,编号设为主键,并且是自增长的,然后这张表还有其他字段,工作卡号,姓名,公司系统帐号,密码。现在我有两条数据,工作卡号,姓名,公司系统帐号,密码都一样,就只有编号不同,有人离职,需要删除其中一条数据,为什么我删除的都会是两条同时删除,BLL层的代码是这样:public void delete(string Card_ID) { string strDel = string.Format("insert into DelSystemTable(ID,Card_ID,UserID,Name,PassWord,CreatTime,SystemName,DeleteTime)select ID, Card_ID,UserID,Name,PassWord,CreatTime,SystemName,getdate() from SystemTable where Card_ID='{0}' delete SystemTable where Card_ID='{0}'", Card_ID); sqlH.ExSql(strDel); }
解决方案
原因是你的删除语句用Card_ID作为条件. 上面你也说了,这两条数据除了自增ID不一样以外,其它的都一样.你用Card_ID作为删除条件.在执行时,两条数据符合,肯定都被删除掉了. 要删除其中的一条,删除条件要使用自增ID
where Card_ID= ... 改成 where ID=...
解决方案二:
工作卡号,姓名,公司系统帐号,密码都一样,就只有编号不同
delete SystemTable where Card_ID='{0}'
你的card_id应该是工作卡号,因为工作卡号一样所以删除掉两行,你条件里直接用编号(因为编号不同),就没有这个问题了
时间: 2024-11-03 18:14:59