我想使用ExecuteQuery()来获取Entities.UserLevel类型的IEnumerable。下面的代码运行得很好。
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类来代替上面的类:
public class UserLevel
{
public int UserIdentity { get; set; }
public int LevelIdentity { get; set; }
}发布于 2012-10-12 02:51:23
当然,只要写下来就行了。
var q = "SELECT userID as UserIdentity, levID as LevelIdentity FROM UserLevel";
var res = context.ExecuteQuery<UserLevelDTO>(q);但是为什么不使用Linq呢?你可以这样写:
var res = from u in context.UserLevel
select new UserLevelDTO()
{
UserIdentity = u.userID,
LevelIdentity = u.levID
};您需要创建自己的DTO类。
public class UserLevelDTO
{
public int UserIdentity { get; set; }
public int LevelIdentity { get; set; }
}https://stackoverflow.com/questions/12846448
复制相似问题