0

我有一个函数,GetUserByOpenId 我根本不想使用这个函数

    Public Function GetUserByOpenID(ByVal claimedidentifier As String) As User Implements IUserRepository.GetUserByOpenID
        Dim user = (From u In dc.Users
                    Join o In dc.OpenIDs On u.ID Equals o.UserID
                    Where o.ClaimedIdentifier = claimedidentifier
                    Select u).FirstOrDefault
        Return user
    End Function

我真正想做的是使用我的“GetUsers”函数(IQueryable)并在我的服务层中执行 JOIN。

    Public Function GetUsers() As IQueryable(Of User) Implements IUserRepository.GetUsers
        Dim users = (From u In dc.Users
                    Select u)
        Return users.AsQueryable
    End Function

谁能告诉我使用与此类似的函数返回适当数据的方法是什么样的

    Public Function GetAllUsers() As System.Collections.Generic.IList(Of User) Implements IUserService.GetAllUsers
        Return _UserRepository.GetUsers().Where(Function(u) (Not u.isClosed)).ToList
    End Function
4

1 回答 1

0

嗯,您似乎应该在 OpenID 和用户之间建立 FK 关系,但您没有。如果您创建此关系,您将能够轻松地通过属性遍历它,而根本不需要进行查询(除了简单的 Where 之外)。

于 2010-07-04T18:11:48.853 回答