1

在我的演示解决方案中,我有两个项目 DataAccess 和 WebInterface。

在 DataAccess 项目中,我有一个用户 EF 和一个类文件 UserDataAccessService.cs

UserDataAccessService.cs 中的代码:-

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Entity;
using System.Data.EntityClient;
using System.Data.SqlClient;
using System.Data;
using DataAccess.User;

namespace DataAccess.User
{

    public sealed class UserDataAccessService
    {

        private string efConnectionString;        
        private string portalConnectionString;

        public string ConnectionString
        {
            get {  return efConnectionString;   }
        }
        public UserDataAccessService(string portalConnectionString)
        {
            this.portalConnectionString = portalConnectionString;
            this.efConnectionString = GetConnectionString(portalConnectionString);
        }
        private string GetConnectionString(string portalConnectionString)
        {
            EntityConnectionStringBuilder entityBuilder = new EntityConnectionStringBuilder();
            entityBuilder.Provider = "System.Data.SqlClient";
            entityBuilder.ProviderConnectionString = portalConnectionString;
            entityBuilder.Metadata = "res://*/User.ProgramModel.csdl|res://*/User.UserModel.ssdl|res://*/User.UserModel.msl";
            return entityBuilder.ToString();
        }
        public IEnumerable<User> GetUsers(int? userId, bool? status)
        {
            using (Users objectContext = new Users(efConnectionString))
            {
                return objectContext.GetUsers(null, null);
            }
        }
    }
}

现在在 WebInterface 项目中,我只是有一个 ManageUsers.aspx 页面,我试图通过下面的代码获取用户列表

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Configuration;
using System.Data;
using DataAccess.User;
namespace WebInterface
{
    public partial class ManageUser : System.Web.UI.Page
    {

        protected void Page_Load(object sender, EventArgs e)
        {
            UserDataAccessService usrObj = new UserDataAccessService(ConfigurationManager.ConnectionStrings["portalConn"].ToString());
            List<User> userLst = new List<User>();   
            userLst =  usrObj.GetUsers(1, null).ToList();
        }
    }
}

问题:-当我构建解决方案时,我收到以下错误:-

Error 1
The type 'System.Data.Objects.DataClasses.EntityObject' is defined in an assembly that is not referenced. 
You must add a reference to assembly 'System.Data.Entity, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089'.

D:\Practice\PTP\UI\WebInterface\User\ManageUser.aspx.cs
18 13
WebInterface

为了修复它,我将它 System.Data.Entity.dll 包含在 WebInterface 项目的参考文件夹中,该文件夹已修复了该问题。

我的问题:

如果您查看我的代码,那么您可以发现与代码相关的 EF 都在 DataAccess 项目中,其中包含与 EF 相关的类所需的所有必需的 dll 引用。

在 WebInterface 项目中,我包含了 DataAccess.dll,在其中的 .aspx 页面中,我只是将其调用为获取数据的函数。

那么为什么它在 WebInterface 项目中也需要 System.Data.Entity.dll 呢?

问候

瓦伦

4

1 回答 1

0

我只有 99% 的把握,因为您使用的是一些老式的 EF :) 并且您没有共享 User 类,但是......我认为是 EntityFramework 感知的 User 类。User是从EntityObject继承的吗?

您可以通过将数据从实体类映射到您的 UI 类来避免这种情况。但这需要使用 EF 的所有魔力。

于 2013-04-10T19:07:20.030 回答