3

我正在研究 winRT 和实体框架(到 SQL),它们之间通信的层是 WCF 服务。在实体框架中,我使用的是存储库模式,并且我有以下方法:

public IQueryable<User> GetBySearch(Expression<Func<User, bool>> search)
{
    return this.Context.Users.Where(search);
}

一切正常,但是当我将它添加到 WCF

[OperationContract]
IQueryable<User> GetUserBySearch(Expression<Func<User, bool>> search);

和:

public IQueryable<User> GetUserBySearch(Expression<Func<User, bool>> search)
{
    IUser user = new UserRepository();
    return user.GetBySearch(search);
}

但是Expression不可序列化的问题,因此,WCF不能序列化它。所以我想从它继承并使其 [Serializable] 但它是一个密封类的问题。

有人可以帮我解决问题吗?

4

2 回答 2

1

如果您使用的是实体框架,WCF 不能很好地与 Iqueryable 和 lambdas 配合使用。这是一个快速而肮脏的解决方案,请根据您的需要进行调整。

将服务合同更改为

[OperationContract]
IEnumerable<User> GetEventBySearch(UserCriteria search);

其中 UserCriteria 是一个 DataContract,其中包含您需要的每个搜索条件的属性 - 例如:

[DataContract]
public class UserCriteria
{
    [DataMember]
    public string Name { get; set; }

    [DataMember]
    public string Email { get; set; }

    // add a property for each search criteria....
}

服务实现:

public IEnumerable<User> GetEventBySearch(UserCriteria search)
{
    IUser user = new UserRepository();
    Expression<Func<User, bool>> criteria = BuildExpression(search);

    return user.GetBySearch(criteria).AsEnumerable();
}

private Expression<Func<User, bool>> BuildExpression(UserCriteria search)
{
    // build lambda expression here
}
于 2013-08-09T11:14:19.763 回答
0

把你的表达式改成 Func ,你可以使用 BinaryFormatter 或者其他序列化器来序列化

于 2013-08-29T16:43:44.243 回答