16

我有一个错误

在 using 语句中使用的类型必须隐式转换为“System.IDisposable”

在线的

using (var context = new EntityContainer())

这是我的代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.SqlClient;
using System.Globalization;
using System.Data;
using System.Data.Entity;
using school.usi.susibar.model;

namespace school.usi.susibar.test
{
    class Program
    {

        public static void Main(string []args)
         {
            using (var context = new EntityContainer())
            {

                addOrderStatusType(context);

                Console.ReadLine();
            }
        } 


        private static void addOrderStatusType(EntityContainer context)
        {
            try
            {
                OrderStatusType type = new OrderStatusType
                {
                    Name = "Vyrizeno", 
                    CancelPermission = false, 
                    ChangePermission = false
                };
                context.OrderStatusTypes.Add(type);
                context.SaveChanges();
                Console.WriteLine("Pridano");
            }
            catch (Exception ex) {
                Console.WriteLine(ex.InnerException);
            }
        }
         }

            }

EntityContainer() 看起来像这样......

//------------------------------------------------------------------------------
// <auto-generated>
//    This code was generated from a template.
//
//    Manual changes to this file may cause unexpected behavior in your application.
//    Manual changes to this file will be overwritten if the code is regenerated.
// </auto-generated>
//------------------------------------------------------------------------------

namespace school.usi.susibar.model
{
    using System;
    using System.Data.Entity;
    using System.Data.Entity.Infrastructure;

    public partial class EntityContainer : DbContext
    {
        public EntityContainer()
            : base("name=EntityContainer")
        {
        }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            throw new UnintentionalCodeFirstException();
        }

        public DbSet<Role> Roles { get; set; }
        public DbSet<Category> Categories { get; set; }
        public DbSet<Table> Tables { get; set; }
        public DbSet<OrderStatusType> OrderStatusTypes { get; set; }
        public DbSet<Person> Persones { get; set; }
        public DbSet<Item> Items { get; set; }
        public DbSet<Order> Orders { get; set; }
        public DbSet<Stock> Stocks { get; set; }
        public DbSet<ItemOrderList> ItemOrderLists { get; set; }
        public DbSet<ItemOrderStatus> ItemOrderStatuses { get; set; }
        public DbSet<PaymentOrderStatus> PaymentOrderStatuses { get; set; }
        public DbSet<Prepaid> Prepaids { get; set; }
    }
}

编辑: DbContext 实现 IDisposable 并且我无法编辑 EntityContainer() 类,因为它是从模板生成的。

有什么想法有什么问题吗?

4

7 回答 7

59

这个答案

上下文仍然实现 IDisposable,但是如果您遇到错误...抱怨未实现 IDisposable,那么您的问题很可能是您的模型是在引用 EF5 的单独程序集中定义的,并且您没有添加 EF5 引用你的项目。

于 2012-11-25T18:50:21.977 回答
7

答案是将 EntityFramework 程序集添加到引用中

于 2013-06-21T12:24:05.997 回答
5

如果要EntityContainerusing语句中使用,那么它必须实现IDisposable

尝试这个:

public partial class EntityContainer : DbContext, IDisposable
{
    public EntityContainer()
        : base("name=EntityContainer")
    {
    }

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        throw new UnintentionalCodeFirstException();
    }

    public DbSet<Role> Roles { get; set; }
    public DbSet<Category> Categories { get; set; }
    public DbSet<Table> Tables { get; set; }
    public DbSet<OrderStatusType> OrderStatusTypes { get; set; }
    public DbSet<Person> Persones { get; set; }
    public DbSet<Item> Items { get; set; }
    public DbSet<Order> Orders { get; set; }
    public DbSet<Stock> Stocks { get; set; }
    public DbSet<ItemOrderList> ItemOrderLists { get; set; }
    public DbSet<ItemOrderStatus> ItemOrderStatuses { get; set; }
    public DbSet<PaymentOrderStatus> PaymentOrderStatuses { get; set; }
    public DbSet<Prepaid> Prepaids { get; set; }

    public void Dispose()
    {
        base.Dispose();
    }
}
于 2012-11-25T18:18:14.163 回答
4

我在调用项目的引用中添加了实体框架,它解决了我的问题。

于 2015-02-18T16:16:05.977 回答
1

您可以尝试使用工作单元模式,例如这样。

public interface IUnitOfWork : IDisposable {
    void Save();
}

然后你的部分 ObjectContext 可以实现IUnitOfWork接口:

public partial class EntityContainer : IUnitOfWork {
    public void Save() {
        this.SaveChanges();
    }

    void IDisposable.Dispose() {
        base.Dispose();
    }
}

此方法允许我使用 using 指令而不会出错。使用示例(我将存储库模式与此结合使用):

    public List<OrderModelView> GetAllOrdersAscByName() {

        using (IUnitOfWork context = new EntityContainer()) {
            Repository<Order> orderRepository = new Repository<Order>(context);

            var orders = orderRepository.GetAll()
                .Select(o => new OrderModelView {
                    OrderID = o.OrderID,
                    Name = o.Name,
                    OrderTypeCount = o.OrderTypes.Count
                })
                .OrderBy(o => o.Name)
                .ToList();

            return orders;
        }
    }

希望这会有所帮助。

于 2013-02-27T22:29:16.407 回答
0

我们有一个页面抛出这个错误和does not contain a definition for SaveChanges错误。实体是在一个单独的项目中定义的,并且似乎使用了所有必要的引用。

我发现在编辑页面时从 Visual Studio 2012 切换到 2010 就足够了。这绝对不是理想的,但在我们将所有内容切换到 EF 5+ 之前它可以工作。

于 2014-03-18T19:42:36.537 回答
0

如果您使用 Visual Studio 2013 遵循“Pro C# 5.0 和 .Net 4.5 框架”第 23 章中的示例,则只需将其他 DLL 添加到 AutoLotDAL 文件夹中作为参考。

于 2015-11-05T10:13:27.523 回答