0

Entity Framework Code First データ層を使用して WCF REST サービスを開発しており、ナビゲーション プロパティがあります。

ユーザークラス:

[DataContract]
public class User
{
    [DataMember]
    public int UserId { get; set; }

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

    [DataMember]
    public int Age { get; set; }

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

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

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

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

    [DataMember]
    public virtual ICollection<User> Friends { get; set; }

    [DataMember]
    public virtual ICollection<User> FromWhomIsFriend { get; set; }
}

ServiceContractメソッド:

public List<User> GetUserFriends(string user_id)
{
    int userId;
    OutgoingWebResponseContext ctx =
        WebOperationContext.Current.OutgoingResponse;

    if ((user_id == null) ||
        (!Int32.TryParse(user_id, out userId)) ||
        (userId < 1))
    {
        ctx.StatusCode = System.Net.HttpStatusCode.BadRequest;
        ctx.StatusDescription = "user_id parameter is not valid";
        throw new ArgumentException("GetUserFriends: user_id parameter is not valid", "user_id");
    }

    List<User> friends = null;

    try
    {
        using (var context = new AdnLineContext())
        {
            context.Configuration.ProxyCreationEnabled = false;
            context.Configuration.LazyLoadingEnabled = false;

            var users = from u in context.Users.Include("Friends")
                        where u.UserId == userId
                        select u;

            if ((users != null) &&
                (users.Count() > 0))
            {
                User user = users.First();
                //friends = user.Friends.ToList();

                friends = new List<User>();
                foreach (User f in user.Friends)
                {
                    User us = new User()
                    {
                        UserId = f.UserId,
                        Name = f.Name,
                        Age = f.Age,
                        City = f.City,
                        Country = f.Country,
                        Email = f.Email,
                        InterestIn = f.InterestIn,
                        Friends = f.Friends,
                        FromWhomIsFriend = f.FromWhomIsFriend
                    };
                    friends.Add(us);
                }
            }

            ctx.StatusCode = System.Net.HttpStatusCode.OK;
        }
    }
    catch (Exception ex)
    {
        ctx.StatusCode = System.Net.HttpStatusCode.InternalServerError;
        ctx.StatusDescription = ex.Message; 
        ctx.SuppressEntityBody = true;
    }

    return friends;
}

このメソッドは何も返しません。この行にコメントFromWhomIsFriend = f.FromWhomIsFriendすると機能します。

FromWhomIsFriend私が彼の友人であるユーザーへのナビゲーションプロパティです。ユーザー関係を表すために、次の表があります。

UserID   | FriendID
---------+----------
  3      |    1
---------+----------
  1      |    2

ユーザー 1 の友達について尋ねると、ユーザー 2 が表示され、FromWhomIsFriendユーザー 1 を指しています。ユーザー 1Friendsのナビゲーション プロパティはユーザー 2 を指しており、続きます。

なぜ私が何も返さないのか知っていますか?

4

1 に答える 1

1

遅延読み込みをサポートするには、プロキシの作成を有効にする必要があります。できることはInclude、クエリで使用してナビゲーション プロパティをロードすることです。

        var users = from u in context.Users.Include(u=>u.Friends)
                    where u.UserId == userId
                    select u;

または、別のソリューションは、WCF コントラクト (DTO) として別のオブジェクト モデルを使用しています。次に、遅延読み込みを有効にしてから、必要なすべての値を EF エンティティ オブジェクト (プロキシ) から新しいデータ転送オブジェクトにコピーできます。Automaperのようなものを使用して、オブジェクトを簡単にマップできます。

于 2013-08-12T11:10:45.983 に答える