WCF RIA Services & EF - Tip: Silverlight端访问外键关联实体

本文详细阐述了在使用DomainService结合EF4进行数据访问时,通过Include语句确保关联实体在客户端代码正确生成的方法,并提供了解决银光镜端job.Vehicle出现null值的技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:在Domain Service中使用EF 4 实现如下数据访问,通过Include语句获得Job所关联的Vehicle实体

 

public IQueryable<Job> GetRunsByVehicleDate(int vehicleID, DateTime date)
        {
            date = date.Date;
            DateTime dateNext = date.AddDays(1);
            var result = this.ObjectContext.Jobs.Include("Vehicle").Include("Location").Include("TimeSlot")
                                           .Where(j => j.JobDate >= date && j.JobDate <= dateNext && j.VehicleID == vehicleID)
                                           .OrderBy(j => j.JobDate);
            return result;
         
        }

 

然而在Silverlight端,job.Vehicle 得到的却是null

 

原因:RIA没有将关联实体在客户端代码上正确生成

 

解决:使用Include 属性并修饰Job实体如下,

 

    [MetadataType(typeof(JobMetaData))]
    partial class Job : IEntity
    {

        public class JobMetaData
        {
            [Include]
            public Vehicle Vehicle { get; set; }

            [Include]
            public Location Location { get; set; }
           
        }
    }

 

注意:Include来自 System.ServiceModel.DomainServices.Server.dll at path like

C:/Program Files (x86)/Microsoft SDKs/RIA Services/v1.0/Libraries/Server

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值