当前位置:  开发笔记 > 编程语言 > 正文

实体框架通用存储库错误

如何解决《实体框架通用存储库错误》经验,为你挑选了1个好方法。

我正在尝试为我的Entity Framework存储库创建一个非常通用的泛型存储库,该存储库具有基本的CRUD语句并使用接口.我先打了一个砖墙头,然后被打倒了.这是我的代码,使用实体框架模型在控制台应用程序中编写,其中包含一个名为Hurl的表.只需尝试通过其ID撤回对象.这是完整的应用程序代码.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Objects;
using System.Linq.Expressions;
using System.Reflection;
using System.Data.Objects.DataClasses;

namespace GenericsPlay
{
    class Program
    {
        static void Main(string[] args)
        {
            var hs = new HurlRepository(new hurladminEntity());
            var hurl = hs.Load(h => h.Id == 1);
            Console.Write(hurl.ShortUrl);
            Console.ReadLine();

        }
    }

    public interface IHurlRepository
    {
        T Load(Expression> expression);
    }

    public class HurlRepository : IHurlRepository, IDisposable 
    {

        private ObjectContext _objectContext;

        public HurlRepository(ObjectContext objectContext)
        {
            _objectContext = objectContext;
        }

        public ObjectContext ObjectContext
        {
            get
            {
                return _objectContext;
            }
        }

        private Type GetBaseType(Type type)
        {
            Type baseType = type.BaseType;
            if (baseType != null && baseType != typeof(EntityObject))
            {
                return GetBaseType(type.BaseType);
            }
            return type;
        }

        private bool HasBaseType(Type type, out Type baseType)
        {
            Type originalType = type.GetType();
            baseType = GetBaseType(type);
            return baseType != originalType;
        }

        public IQueryable GetQuery()
        {
            Type baseType;
            if (HasBaseType(typeof(T), out baseType))
            {
                return this.ObjectContext.CreateQuery("[" + baseType.Name.ToString() + "]").OfType();
            }
            else
            {
                return this.ObjectContext.CreateQuery("[" + typeof(T).Name.ToString() + "]");
            }
        }

        public T Load(Expression> whereCondition)
        {
            return this.GetQuery().Where(whereCondition).First(); 
        }

        public void Dispose()
        {
            if (_objectContext != null)
            {
                _objectContext.Dispose();
            }
        }
    }

}

这是我得到的错误:

    System.Data.EntitySqlException was unhandled
  Message="'Hurl' could not be resolved in the current scope or context. Make sure that all referenced variables are in scope, that required schemas are loaded, and that namespaces are referenced correctly., near escaped identifier, line 3, column 1."
  Source="System.Data.Entity"
  Column=1
  ErrorContext="escaped identifier"
  ErrorDescription="'Hurl' could not be resolved in the current scope or context. Make sure that all referenced variables are in scope, that required schemas are loaded, and that namespaces are referenced correctly."

这是我试图从中提取此信息的地方.

http://blog.keithpatton.com/2008/05/29/Polymorphic+Repository+For+ADONet+Entity+Framework.aspx



1> Jeff Ancel..:

好吧,这个让我感到困惑.我采取了狂野的刺(在Stephen Walther即将推出的ASP.NET MVC Unleashed书中看到EFRepository的一部分后)它开始工作,这里是修复(替换此方法,注意字符串格式的差异).有关为何这样做的任何建议?我看到这个的方式,可能是一个bug(或者我正在做的事情).无论如何,任何有兴趣的人.(我想想修复这部分将修复EFRepository @ Keith Patton的博客文章的整个功能).

public IQueryable GetQuery()
{
    Type baseType;
    if (HasBaseType(typeof(T), out baseType))
    {
        return this.ObjectContext.CreateQuery(String.Format("[{0}]", baseType.Name.ToString())).OfType();
    }
    else
    {
        return this.ObjectContext.CreateQuery(String.Format("[{0}]", typeof(T).Name.ToString()));
    }
}

推荐阅读
wangtao
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有