我目前得到这个错误:
System.Data.SqlClient.SqlException:不允许新的Business,因为会话中还有其他线程正在运行。
运行这个代码时:
public class ProductManager : IProductManage{    #region Declare Models    private RivWorks.Model.Negotiation.RIV_Entities _dbRiv = RivWorks.Model.Stores.RivEntities(AppSettings.RivWorkEntities_connString);    private RivWorks.Model.NegotiationAutos.RivFeedsEntities _dbFeed = RivWorks.Model.Stores.FeedEntities(AppSettings.FeedAutosEntities_connString);    #endregion    public IProduct GetProductById(Guid productId)    {        // Do a quick sync of the feeds...        SyncFeeds();        ...        // get a product...        ...        return product;    }    private void SyncFeeds()    {        bool found = false;        string feedSource = "AUTO";        switch (feedSource) // companyFeedDetail.FeedSourceTable.ToUpper())        {            case "AUTO":                var clientList = from a in _dbFeed.Client.Include("Auto") select a;                foreach (RivWorks.Model.NegotiationAutos.Client client in clientList)                {                    var companyFeedDetailList = from a in _dbRiv.AutoNegotiationDetails where a.ClientID == client.ClientID select a;                    foreach (RivWorks.Model.Negotiation.AutoNegotiationDetails companyFeedDetail in companyFeedDetailList)                    {                        if (companyFeedDetail.FeedSourceTable.ToUpper() == "AUTO")                        {                            var company = (from a in _dbRiv.Company.Include("Product") where a.CompanyId == companyFeedDetail.CompanyId select a).First();                            foreach (RivWorks.Model.NegotiationAutos.Auto sourceProduct in client.Auto)                            {                                foreach (RivWorks.Model.Negotiation.Product targetProduct in company.Product)                                {                                    if (targetProduct.alternateProductID == sourceProduct.AutoID)                                    {                                        found = true;                                        break;                                    }                                }                                if (!found)                                {                                    var newProduct = new RivWorks.Model.Negotiation.Product();                                    newProduct.alternateProductID = sourceProduct.AutoID;                                    newProduct.isFromFeed = true;                                    newProduct.isDeleted = false;                                    newProduct.SKU = sourceProduct.StockNumber;                                    company.Product.Add(newProduct);                                }                            }                            _dbRiv.SaveChanges(); // ### THIS BREAKS ### //                        }                    }                }                break;        }    }}模型#1 - 这个模型位于我们的开发服务器的数据库中。
、 http://content.screencast.com/users/Keith.Barrows/folders/Jing/media/bdb2b000-6e60-4af0-a7a1-2bb6b05d8bc1/Model1.png
模型#2 - 此模型位于Prod服务器上的数据库中,并且每天都通过自动提要进行更新。
alt text http://content.screencast.com/users/Keith.Barrows/folders/Jing/media/4260259f-bce6-43d5-9d2a-017bd9a980d4/Model2.png
注 - 模型#1中红圈的项目是我用来“映射”到模型#2的字段。请忽略模型2中的红色圆圈:这是我现在回答的另一个问题。
注意:我仍然需要放入一个isDeleted检查,以便我可以从DB1软删除它,如果它已经离开我们客户的库存。
所以最大的问题 - 我如何解决我所得到的交易错误? 我是否需要每次通过循环删除和重新创建我的上下文?
相似问题