2 kb 2416 KB_2416 于 2013.06.07 16:12 提问

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);
    }

2个回答

zhanglei5415
zhanglei5415   Rxr 2013.06.07 16:48

原因是你的删除语句用Card_ID作为条件. 上面你也说了,这两条数据除了自增ID不一样以外,其它的都一样.你用Card_ID作为删除条件.在执行时,两条数据符合,肯定都被删除掉了. 要删除其中的一条,删除条件要使用自增ID
where Card_ID= ... 改成 where ID=...

lzp_lrp
lzp_lrp   Ds   Rxr 2015.05.30 23:29

工作卡号,姓名,公司系统帐号,密码都一样,就只有编号不同

delete SystemTable where Card_ID='{0}'

你的card_id应该是工作卡号,因为工作卡号一样所以删除掉两行,你条件里直接用编号(因为编号不同),就没有这个问题了

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!