急急急 !EF框架中的事务处理问题(对同一张表进行操作)

xuefeng_zzg 2014-12-22 11:08:46
在对一张表进行批量更新的时候本人采取的是这样一种方法。先把相关记录都删除,然后再新增记录。
如下
表中记录
1、 a
2、 b
3、 c
我先全都删除然后插入
1、 a
2、 c
3、 d
4、 e
可是运行总是报错,说是插入了重复键。
以下是代码
public bool UpdateCellDataConfig(List<RPEDCellDataConfigInfo> cellDataConfigInfoList, string reportID, string organizationID, string strConnection)
{
using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required))
{
try
{
using (var context = new RPEDDbContext(strConnection))
{
var dcList = from o in context.RPEDCellDataConfigInfo
where o.ReportID == reportID
select o;
List<RPEDCellDataConfigInfo> p = (List<RPEDCellDataConfigInfo>)dcList.ToList();
foreach (RPEDCellDataConfigInfo item in p)
{
context.RPEDCellDataConfigInfo.Remove(item);

}
context.SaveChanges();

if (cellDataConfigInfoList != null && cellDataConfigInfoList.Count > 0)
{
foreach (RPEDCellDataConfigInfo iteminfo in cellDataConfigInfoList)
{
context.RPEDCellDataConfigInfo.Add(iteminfo);
}
}
context.SaveChanges();
}
scope.Complete();
return true;
}
catch (Exception e)
{
return false;
throw new Exception("配置信息提交失败." + e.Message);
}
finally
{
scope.Dispose();
}
}
}
...全文
381 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
qiushangju 2018-09-20
  • 打赏
  • 举报
回复
把主键查出来后又重新插入了呗
haohaoxuexihere 2014-12-23
  • 打赏
  • 举报
回复
是不是因为主键的原因,没有自增?还是说在插入的时候需要指定自增列
xuefeng_zzg 2014-12-23
  • 打赏
  • 举报
回复
调试过了在第一次context.SaveChanges();的时候context.RPEDCellDataConfigInfo的记录是0,但是在下面执行到context.RPEDCellDataConfigInfo.Add(iteminfo);的时候context.RPEDCellDataConfigInfo的记录又变成3了,感觉就是上面根本没有删除一样
  • 打赏
  • 举报
回复
另外我一直强调的是,程序员必须能够准确贴出调试中断信息,调试器必须准确停在抛出异常的那一条语句上,程序员必须能够调试抛出异常时的各种数值(例如最肤浅的 inteminfo )。如果看不到这种能力,只知道打印出个 exception.Message 给领导“来解决”的程序员,我们都调去搞维护了。干开发的基本素质就是会准确调试。
  • 打赏
  • 举报
回复
既然它“说是插入了重复键”,你自己不去调试查找重复键,还等什么?
xuefeng_zzg 2014-12-23
  • 打赏
  • 举报
回复
ef框架用起来真心蛋疼,报的错误都是英文的,网上找答案都不容易
jhdxhj 2014-12-23
  • 打赏
  • 举报
回复
引用 3 楼 xuefeng_zzg 的回复:
领导说用ef框架开发的啊。sql实现很容易,关键想知道用ef这里为什么会出现问题。可以下回避免
那就问领导,如果领导自己都不懂EF,这不是扯淡吗?
xuefeng_zzg 2014-12-23
  • 打赏
  • 举报
回复
领导说用ef框架开发的啊。sql实现很容易,关键想知道用ef这里为什么会出现问题。可以下回避免
xuefeng_zzg 2014-12-23
  • 打赏
  • 举报
回复
引用 9 楼 haohaoxuexihere 的回复:
是不是因为主键的原因,没有自增?还是说在插入的时候需要指定自增列
不是,因为我是先把所有记录都删除了然后添加上他目前的记录,没有涉及到自增列。
jhdxhj 2014-12-22
  • 打赏
  • 举报
回复
坐等,为什么不是SQL?
xuefeng_zzg 2014-12-22
  • 打赏
  • 举报
回复
求大神解答!
内容简介   《google android sdk开发范例大全(第3版)》在上一版的基础上,以android手机应用程序开发(采用android sdk 2.3.3)为主题,超过200多个范例全面且深度地整合了手机、网络及服务等多个开发领域,为读者提高程序设计能力提供了很大的帮助。    全书共分11章,主要以范例集的方式来讲述android的知识点,详细介绍了开发android的人机交互界面、android常用的开发控件、android手机收发短信等通信服务、开发android手机的自动服务功能和娱乐多媒体功能以及整合android与google强大的网络服务等内容。随书光盘包括了所有范例的程序代码。    《google android sdk开发范例大全(第3版)》继承前两版由浅入深的方式,范例总数由原先的160多个增加到了200多个,在用户交互界面、手机控件、交互式通信服务、手机自助服务、娱乐多媒体等方面均增加了相应的范例来介绍新的开发技术,特别是新增加了第11章来专门介绍html5技术在android移动设备里的应用,相信当下两个热门技术的交汇会碰撞出不一样的火花。    《google android sdk开发范例大全(第3版)》内容由android的基础知识到实际开发应用,结构清晰、语言简洁,非常适合android的初学者和android的进阶程序开发者阅读参考。 目录 《google android sdk开发范例大全(第3版)》 第1章 了解、深入、动手做 1 1.1 红透半边天的android 2 1.2 本书目的及范例涵盖范围 3 1.3 如何阅读本书 4 1.4 使用本书范例 5 1.5 参考网站 6 第2章 android初体验 7 2.1 安装android sdk与adt/ddms 8 2.2 创建第一个android项目(hello android!) 11 2.3 android应用程序架构——从此开始 15 2.4 可视化的界面开发工具 18 2.5 部署应用程序到android手机 19 第3章 用户人机界面 22 3.1 更改与显示文字标签 23 3.2 更改手机窗口画面底色 24 3.3 更改textview文字颜色 26 3.4 置换textview文字 28 3.5 取得手机屏幕大小 29 3.6 样式化的定型对象 30 .3.7 简易的按钮事件 32 3.8 手机页面的转换 34 3.9 调用另一个activity 37 3.10 不同activity之间的数据传递 41 3.11 返回数据到前一个activity 44 3.12 具有交互功能的对话框 49 3.13 置换文字颜色的机关 51 3.14 控制不同的文字字体 52 3.15 如iphone拖动相片特效 54 3.16 自制计算器 56 3.17 关于(about)程序信息 58 3.18 程序加载,请稍候 61 3.19 全屏幕以按钮重写 63 3.20 今晚到哪儿打牙祭 64 3.21 android变脸 67 3.22 打勾显示输入的密码 69 3.23 android多语系支持 71 3.24 判断手机操作系统版本是否允许运行程序 72 3.25 两个不同的程序彼此调用 75 3.26 指定安装应用程序迁移至sd卡 78 3.27 手机动态layout主题随手势物换迁移 79 第4章 史上超豪华的手机控件 84 4.1 edittext与textview共舞 85 4.2 设计具有背景图的按钮 86 4.3 给圣诞老人的信息 88 4.4 我同意条款 90 4.5 消费券采购列 92 4.6 向左或向右 94 4.7 专业相框设计 96 4.8 自定义下拉菜单模式 99 4.9 动态添加/删除的spinner菜单 102 4.10 心爱小宝贝相片集 104 4.11 快速地搜索手机文件引擎 107 4.12 按钮也能随单击变换 109 4.13 具自动提示功能的菜单 110 4.14 数字及模拟小时钟设计 112 4.15 动态输入日期与时间 114 4.16 猜猜红桃a在哪儿 117 4.17 后台程序运行进度提示 121 4.18 动态文字排版 124 4.19 在activity里显示列 128 4.20 以动态列配置选项 130 4.21 查找程序根目录下所有文件 134 4.22 加载手机磁盘里的图片文件 137 4.23 动态放大缩小imageview里的图片 139 4.24 动态旋转图片 142 4.25 猜猜我在想什么 145 4

110,567

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧