EF中的transaction的使用范例
注意一点:
在EF中使用事物后,对于一个新增的model,在saveChanges后,可以得到该实体的自增ID,但在提交事物之前,
该数据并没有真正的新增到DB中,但此时可以得到model新增的自增ID,程序中可以使用,很方便!
例如下面的series实体在新增时,下面新增level时就可以直接使用,但此时的series并没有真正的新增到db中。
/// <summary>
/// 导入汽车维护数据
/// </summary>
/// <param name="BrandName"></param>
/// <returns></returns>
public static Result ImportVehicleData(string strDataTable)
{
DataTable dt = JsonHelper.Deserialize<DataTable>(strDataTable);
if (dt != null)
{
using (Entities db = new Entities())
{
using (TransactionScope transaction = new TransactionScope())
{
try
{
var brandList = db.TL_Sys_VehicleBrand.ToList();
var seriesList = db.TL_Sys_VehicleSeries.ToList();
var levelList = db.TL_Sys_VehicleLevel.ToList();
string brandName = "";
string seriesName = "";
string levelName = "";
bool isInterest = true;
bool isDefault = true;
TL_Sys_VehicleBrand brand = new TL_Sys_VehicleBrand();
TL_Sys_VehicleSeries series = new TL_Sys_VehicleSeries();
bool isSave = false;
foreach (DataRow dr in dt.Rows)
{
brandName = dr[0].ToString().Trim();
isInterest = dr[3].ToString().Trim() == "否" ? false : true;
isDefault = dr[4].ToString().Trim() == "否" ? false : true;
brand = brandList.Where(p => p.Name == brandName).FirstOrDefault();
seriesName = dr[1].ToString().Trim();
series = seriesList.Where(p => p.CarBrandID == brand.ID && p.Name.Trim().Replace(" ", "") == seriesName.Trim().Replace(" ", "")).FirstOrDefault();
if (series == null)
{
series = new TL_Sys_VehicleSeries();
//新增车辆车系
series.CarBrandID = brand.ID;
series.Name = seriesName;
series.Code = GetVehicleSeriesNextCode(brand, seriesList);
series.IsInterest = isInterest;
series.IsDefault = isDefault;
db.TL_Sys_VehicleSeries.Add(series);
db.SaveChanges();
seriesList.Add(series);
}
levelName = dr[2].ToString().Trim();
if (!string.IsNullOrWhiteSpace(levelName) && series != null && series.ID > 0)
{
var level = levelList.Where(p => p.CarLineID == series.ID && p.Name.Trim().Replace(" ", "") == levelName.Trim().Replace(" ", "")).FirstOrDefault();
if (level == null)
{
level = new TL_Sys_VehicleLevel();
//新增车辆车型
level.CarLineID = series.ID;
level.Name = levelName;
level.Code = GetVehicleLevelNextCode(series, levelList);
level.IsInterest = isInterest;
level.IsDefault = isDefault;
db.TL_Sys_VehicleLevel.Add(level);
//db.SaveChanges();
isSave = true;
levelList.Add(level);
}
}
}
//如果有新增的车型,就一起保存数据库
if (isSave)
{
db.SaveChanges();
}
transaction.Complete();
return new Result(true, "导入成功");
}
catch(Exception er)
{
transaction.Dispose();
return new Result(false, "导入发生异常," + er.ToString());
}
}
}
}
return new Result(false, "导入汽车信息不能为空");
}
EF中的transaction的使用范例的更多相关文章
- 在EF中正确的使用事务
1.EF中使用事务: using (TransactionScope tran = new TransactionScope()) { try { using(var _context = new D ...
- EF Core利用Transaction对数据进行回滚保护
What? 首先,说一下什么是EF Core中的Transaction Transaction允许以原子方式处理多个数据库操作,如果事务已提交,则所有操作都应用于数据库,如果事务回滚,则没有任何操作应 ...
- Entity Framework入门教程(19)---EF中使用事务
EF中使用事务 这节介绍EF6中事务的使用.EF core中事务的使用方式和EF6中一模一样. 1.EF中的默认的事务 默认情况下,当我们执行一个SaveChanges()方法时就会新建了一个事务,然 ...
- 1.【使用EF Code-First方式和Fluent API来探讨EF中的关系】
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/relationship-in-entity-framework-using-code-firs ...
- 2.EF中 Code-First 方式的数据库迁移
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/code-first-migrations-with-entity-framework/ 系列目 ...
- EF中扩展出Between操作符 (修订版)
随手记录一下,这是针对原文错误的修改. 原文:EF中扩展出Between操作符 直接使用是错误的,修改后的扩展方法: /// <summary> /// 扩展 Between 操作符 // ...
- 如何在EF中实现left join(左联接)查询
在EF中,当在dbset使用join关联多表查询时,连接查询的表如果没有建立相应的外键关系时,EF生成的SQL语句是inner join(内联),对于inner join,有所了解的同学都知道,很多时 ...
- EF中执行sql语句,以及事务
EF to sql string sql = "select T_Task.BSID,T_Task.CloseDate,T_Task.CompleteDate,T_Task.CloseUse ...
- EF架构~在ef中支持IQueryable级别的Contains被翻译成了Exists,性能可以接受!
回到目录 Entityframeworks很聪明 不错,非常不错!ef里的contains比linq to sql里的contains有了明显的提升,事实上,是在进行SQL语句翻译上有所提升,在lin ...
随机推荐
- ORACLE触发特定的解释
ORACLE PL/SQL编程八: 把触发器说透 本篇主要内容例如以下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 ...
- 懒与馋的平衡:餐饮O2O市场广阔,发展不易
餐饮行业是众多行业中O2O起步较早的,现在方兴未艾的团购站点中最先涉足的领域就有餐饮版块.长时间的合作推广,很多餐饮商家已经从中尝到甜头,可以说餐饮行业市场基础培育的比較好,所以餐饮O2O 已经是大势 ...
- 读书时间《JavaScript高级程序设计》五:DOM
DOM(文档对象模型)是针对HTML文档的一个API,描绘了一个层次化的节点树,可以添加.移除.修改页面的某一部分. 一个简单的文档结构 <!DOCTYPE html> <html& ...
- 数据收集程序一般建筑(C++ ACE达到)
数据收集程序一般功能 经socket数据的接收的另一侧.端方能够访问智能电表采集器,你可曾与计算机之间的通信的通信协议(你良好的一致性是谁client,谁是服务端,即数据流) 为收集程序要求 可扩展: ...
- Spark SQL 源代码分析系列
从决定写Spark SQL文章的源代码分析,到现在一个月的时间,一个又一个几乎相同的结束很快,在这里也做了一个综合指数,方便阅读,下面是读取顺序 :) 第一章 Spark SQL源代码分析之核心流程 ...
- iOS_18_开关控制器_NavigationController_push道路_数据传输
最后效果图: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcHJlX2VtaW5lbnQ=/font/5a6L5L2T/fontsize/400/fill ...
- 白学jquery Mobile《构建跨平台APP:jQuery Mobile移动应用实战》连续7-电话问卷调查
[例7-3 文本编辑框创建一个简单的调查问卷] 01 <!DOCTYPEhtml> 02 <html> 03 <head> 04 ...
- 学习swift语言的快速入门教程推荐
随着苹果产品越来越火爆,苹果新推出的swift必定将在很大程度上代替oc语言.学好swift语言,对于IOS工程师来讲,已经是一门必备技能. 有一些比较好的英文版教程,值得学习. 1. Swift T ...
- dojo在错误隐藏表行
1.错误叙述性说明 TypeError:role._by_idx[e.rowIndex].hide is not a function (54 out of range 3) 2. ...
- 分散式-ubuntu12.04安装hadoop1.2.1
在hadoop1.2.1被预装在一份报告中安装说明java.我装了很多的版本号java以及许多的版本号hadoop,然后发现oracle-java7与hadoop1.2.1能够匹配. 一,安装详细过程 ...