关于LINQ中SELECT NEW 的问题

 public static object SelectAnyInfo()
{
    DataAccessContext context = new DataAccessContext();
    var query = from c in context.VideoNetServers
                from cc in context.Areas
                from ver in context.VersionItems
                where c.Areas.AreaID == cc.AreaID && 
                      c.VideoNetServerRowID == ver.ResourceRowID &&
                      ver.ResourceTableName.Contains("VIDEONETSERVERS") &&
                      ((ver.VersionTo == int.MaxValue) || (ver.VersionTo == 0 && ver.Action != "删除")) 
                orderby c.VideoNetServerID
                select new 
                {
                    c.VideoNetServerRowID,
                    c.VedeoNetServerName,
                    c.VedeoNetServerCode,
                    c.IPAddress,
                    cc.AreaName
                };
    return query;
}

public static List<Plant> GetData
{
    get{
        var ds = DataAccess.VideoNetServers.SelectAnyInfo();

        List<Plant> data = new List<Plant>();

        foreach (var obj in ds){
        //这个里面无法遍历,Foreach无法定义Var obj
        //麻烦高手看看        
        }
        return data;
}

 

--------------------解决方法------------------

select new 
                { 
                    c.VideoNetServerRowID, 
                    c.VedeoNetServerName, 
                    c.VedeoNetServerCode, 
                    c.IPAddress, 
                    cc.AreaName 
                }; 
将上述代码定义成一个MyClass类
public static List<MyClass> SelectAnyInfo() 

 return query.ToList<MyClass>();

转载于:https://www.cnblogs.com/zhangq/p/10309714.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值