dbcontext throwAmbiguousMatchException

时间:2013-03-05 12:44:24

标签: c# xml entity-framework serialization dbcontext

我尝试将类序列化为xml。 在序列化之后,我想更新statusid。 我能够找到第一个订单并改变statusId,当转到第二个orderid时,这里是我遇到模糊匹配发现错误的地方。

这是主要方法:

 using (var Context = new Context())
            {


                var orderRepo = new OrderRepository(Context);

                foreach (var orderId in orderIds)
                {
                    var order = orderRepo.Find(orderId);
                    order.orderStatusID = 5;

                }
                orderRepo.Save();
            }
OrderRepository.cs中的

     public Order Find(int id)
            {
                return _context.Orders.Find(id);
            }

   public void Save()
        {

            try
            {
                _context.SaveChanges();
            }
            catch (Exception ex)
            {

               _logger.Error(ex);
            }

        }

order.cs:

  [XmlRoot("Orders")]
    [NotMapped]
    public class OrderCollection
    {

        public OrderCollection() { Orders = new List<Order>(); }

        [XmlElement("Order")]
        [NotMapped]
        public List<Order> Orders { get; set; }
    }

    [Serializable()]
    public class Order
    {

        public int id { get; set; }
        [XmlElement("date")]
        public DateTime createdDate
        {
            get
            {
                return (_createdDate == default(DateTime))
                   ? DateTime.Now
                   : _createdDate;
            }

            set { _createdDate = value; }
        }
        private DateTime _createdDate = default(DateTime);

        public string firstName { get; set; }

        public string lastName { get; set; }

        [XmlIgnore]
        public int orderStatusID { get; set; }

    }

1 个答案:

答案 0 :(得分:0)

结果是一个实体有两个成员,同名和不同的套管。一个是数据库中的字段,一个是导航属性。只需重命名,其中一个解决了这个问题。