首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >LINQ ExecuteQuery

LINQ ExecuteQuery
EN

Stack Overflow用户
提问于 2012-10-12 02:46:41
回答 1查看 11.4K关注 0票数 3

我想使用ExecuteQuery()来获取Entities.UserLevel类型的IEnumerable。下面的代码运行得很好。

代码语言:javascript
复制
using (CDataContext context = data.GetDataContext())
{
   string q = "SELECT *FROM UserLevel";
   IEnumerable<Entities.UserLevel> res = context.ExecuteQuery<Entities.UserLevel>(q);
}


public class UserLevel
{
   public int userID { get; set; }
   public int levID { get; set; }
}

但问题是,我必须在UserLevel类中使用与数据库中相同的属性名称,否则我得不到值。我想知道有没有什么方法可以不考虑类/属性名而获得值?例如,我想使用下面的UserLevel类来代替上面的类:

代码语言:javascript
复制
public class UserLevel
{
   public int UserIdentity { get; set; }
   public int LevelIdentity { get; set; }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-10-12 02:51:23

当然,只要写下来就行了。

代码语言:javascript
复制
var q = "SELECT userID as UserIdentity, levID as LevelIdentity FROM UserLevel";
var res = context.ExecuteQuery<UserLevelDTO>(q);

但是为什么不使用Linq呢?你可以这样写:

代码语言:javascript
复制
var res = from u in context.UserLevel
          select new UserLevelDTO()
          {
             UserIdentity = u.userID,
             LevelIdentity = u.levID 
          };

您需要创建自己的DTO类。

代码语言:javascript
复制
public class UserLevelDTO
{
   public int UserIdentity { get; set; }
   public int LevelIdentity { get; set; }
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12846448

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档