3

我有一个引用类库的 asp.net 5 Web 应用程序。

该类库使用 Entity Framework 7 来执行查询。

public IEnumerable<Member> GetMemberyByFirstName(string firstName)
{
    var members = _context.Members.Where(m => m.FirstName.Contains(firstName));
    return memebers;
}

但我得到这个编译错误

'IEnumerable<>' 类型在未引用的程序集中定义。您必须添加对程序集“System.Runtime, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a”的引用。*

4

2 回答 2

3

我已经想出了如何做到这一点,但只是希望信息可用。

它非常复杂,并且围绕 project.json 展开。

非常简短的回答是我将类库中的 project.json 更改为

{
    "version": "1.0.0-*",
    "description": "Member.Business Class Library",
    "authors": [ "bryan" ],
    "tags": [ "" ],
    "projectUrl": "",
    "licenseUrl": "",
    "frameworks": {
        "dnx451": { },
        "dnxcore50": {  
            "dependencies": {
               "Microsoft.CSharp": "4.0.1-beta-23516"
            }
        }
    },
    "dependencies": {
        "EntityFramework.MicrosoftSqlServer": "7.0.0-rc1-final",
        "Member.DataLayer": "1.0.0-*",
        "Member.Domain": "1.0.0-*",
        "System.Collections": "4.0.11-beta-23516",
        "System.Linq": "4.0.1-beta-23516",
        "System.Runtime": "4.0.21-beta-23516",
        "System.Threading": "4.0.11-beta-23516"
    }
}

更多细节可以在这里找到 - http://nodogmablog.bryanhogan.net/2016/01/the-type-is-defined-in-an-assembly-that-is-not-referenced-system-runtime/

于 2016-01-16T05:59:57.707 回答
0

尝试像下面这样返回 -

var members = _context.Members.Where(m => m.FirstName.Contains(firstName)).ToList();

另外,我不明白函数定义-

void IEnumerable<Member>

如果你想退货IEnumerable<Member>,它应该只是IEnumerable<Member>而不是void IEnumerable<Member>

于 2016-01-16T05:43:01.373 回答