- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我创建了一个 T4 模板,它生成标准实体类及其每个属性的接口(interface),这样我就可以制作仅包含我想要的数据的自定义 poco 对象。我还创建了一个复制函数,它可以在实现所述实体接口(interface)的任何对象之间进行转换
生成的代码如下所示
//------------------------------------------------------------------------------
// <auto-generated>
// This code was generated from a template.
//
// Manual changes to this file may cause unexpected behavior in your application.
// Manual changes to this file will be overwritten if the code is regenerated.
// </auto-generated>
//------------------------------------------------------------------------------
namespace DomainModel
{
using System;
using System.Collections.Generic;
using System.Linq;
public interface IRole
{
}
public interface IRole_RoleId : IRole
{
int RoleId { get; set; }
}
public interface IRole_ApplicationName : IRole
{
string ApplicationName { get; set; }
}
public interface IRole_RoleName : IRole
{
string RoleName { get; set; }
}
public interface IRole_Description : IRole
{
string Description { get; set; }
}
public interface IRole_Users : IRole
{
ICollection<IUser> Users { get; set; }
IUser NewUsers();
}
public interface IRole__All : IRole_RoleId,
IRole_ApplicationName,
IRole_RoleName,
IRole_Description,
IRole_Users
{
}
public partial class Role : IRole
{
public Role()
{
this.Users = new HashSet<User>();
}
public int RoleId { get; set; }
public string ApplicationName { get; set; }
public string RoleName { get; set; }
public string Description { get; set; }
public virtual ICollection<User> Users { get; set; }
}
public static class IRoleExt
{
public static T CopyTo<T>(this IRole src , T dest = null ) where T : class, IRole, new()
{
dest = dest ?? new T();
dest.Copy(src);
return dest;
}
public static void Copy(this IRole dest, IRole src)
{
var ms = new MergeStack();
Role role;
if((role = dest as Role) != null){
ms.TryCopy<IRole,Role>((indexCopy) => {return indexCopy(role);}, src);
}
else if ((role = src as Role) != null){
ms.TryCopy<Role,IRole>((indexCopy) => {return indexCopy(dest);}, role);
}
else{
ms.TryCopy<IRole,IRole>((indexCopy) => {return indexCopy(dest);}, src);
}
dest.Copy(src, ms);
}
internal static void Copy(this IRole dest,
IRole src,
MergeStack ms)
{
dest.Set_RoleId(src.Get_RoleId());
dest.Set_ApplicationName(src.Get_ApplicationName());
dest.Set_RoleName(src.Get_RoleName());
dest.Set_Description(src.Get_Description());
dest.Set_Users(src.Get_Users(),ms);
}
public static Nullable<int> Get_RoleId(this IRole src)
{
IRole_RoleId srcIRole_RoleId;
if((srcIRole_RoleId = src as IRole_RoleId) != null )
{
return srcIRole_RoleId.RoleId;
}
Role role;
if((role = src as Role) != null )
{
return role.RoleId;
}
return null;
}
public static void Set_RoleId(this IRole dest, Nullable<int> src)
{
IRole_RoleId destIRole_RoleId;
if((destIRole_RoleId = dest as IRole_RoleId) != null)
{
destIRole_RoleId.RoleId = src.GetValueOrDefault();
}
Role role;
if((role = dest as Role) != null )
{
role.RoleId = src.GetValueOrDefault();
}
}
public static string Get_ApplicationName(this IRole src)
{
IRole_ApplicationName srcIRole_ApplicationName;
if((srcIRole_ApplicationName = src as IRole_ApplicationName) != null )
{
return srcIRole_ApplicationName.ApplicationName;
}
Role role;
if((role = src as Role) != null )
{
return role.ApplicationName;
}
return null;
}
public static void Set_ApplicationName(this IRole dest, string src)
{
IRole_ApplicationName destIRole_ApplicationName;
if((destIRole_ApplicationName = dest as IRole_ApplicationName) != null)
{
destIRole_ApplicationName.ApplicationName = src;
}
Role role;
if((role = dest as Role) != null )
{
role.ApplicationName = src;
}
}
public static string Get_RoleName(this IRole src)
{
IRole_RoleName srcIRole_RoleName;
if((srcIRole_RoleName = src as IRole_RoleName) != null )
{
return srcIRole_RoleName.RoleName;
}
Role role;
if((role = src as Role) != null )
{
return role.RoleName;
}
return null;
}
public static void Set_RoleName(this IRole dest, string src)
{
IRole_RoleName destIRole_RoleName;
if((destIRole_RoleName = dest as IRole_RoleName) != null)
{
destIRole_RoleName.RoleName = src;
}
Role role;
if((role = dest as Role) != null )
{
role.RoleName = src;
}
}
public static string Get_Description(this IRole src)
{
IRole_Description srcIRole_Description;
if((srcIRole_Description = src as IRole_Description) != null )
{
return srcIRole_Description.Description;
}
Role role;
if((role = src as Role) != null )
{
return role.Description;
}
return null;
}
public static void Set_Description(this IRole dest, string src)
{
IRole_Description destIRole_Description;
if((destIRole_Description = dest as IRole_Description) != null)
{
destIRole_Description.Description = src;
}
Role role;
if((role = dest as Role) != null )
{
role.Description = src;
}
}
public static ICollection<IUser> Get_Users(this Role src)
{
return src.Users.Cast<IUser>().ToList();
}
public static ICollection<IUser> Get_Users(this IRole src)
{
IRole_Users srcIRole_Users;
if((srcIRole_Users = src as IRole_Users) != null )
{
return srcIRole_Users.Users;
}
Role role;
if((role = src as Role) != null )
{
return role.Get_Users();
}
return null;
}
public static void Set_Users(this IRole dest, ICollection<IUser> src)
{
var ms = new MergeStack();
dest.Set_Users(src, ms);
}
internal static void Set_Users(this IRole dest, ICollection<IUser> src, MergeStack ms)
{
IRole_Users destIRole_Users;
if((destIRole_Users = dest as IRole_Users) != null)
{
Func<IUser,IUser> iToIFunc = (x=>
ms.TryCopy<IUser,IUser>((indexCopy)=>
{
var ret = destIRole_Users.NewUsers();
var exists = indexCopy(ret);
if(null != exists)
ret = exists;
else
ret.Copy(x,ms);
return ret;
},x));
destIRole_Users.Users = (null !=src)?
src.Select(iToIFunc).ToList():null;
}
Role role;
if((role = dest as Role) != null)
{
Func<IUser,User> iToEFunc = (x=>
ms.TryCopy<IUser,User>((indexCopy)=>
{
var ret = new User();
var exists = indexCopy(ret);
if(null != exists)
ret = exists;
else
ret.Copy(x,ms);
return ret;
},x));
role.Users = (null !=src)?
src.Select(iToEFunc).ToList():null;
}
}
}
}
您看到的那个合并堆栈对象是一个跟踪器,因此我可以处理引用循环。看起来像这样
using System;
using System.Collections.Generic;
using System.Linq;
namespace DomainModel
{
internal class MergeStack
{
private readonly Dictionary<Type, Dictionary<Object, Object>> _mergeObjDict = new Dictionary<Type, Dictionary<object, object>>();
private readonly IList<Action> _registerActions = new List<Action>();
public T TryCopy<TKey, T>(Func<Func<T, T>, T> func, TKey key) where T : class
{
if (key == null)
return null;
Func<T, T> act = (objToIndex) =>
{
Dictionary<object, object> objToObj;
if (!_mergeObjDict.ContainsKey(objToIndex.GetType()))
{
objToObj = new Dictionary<object, object>();
_mergeObjDict.Add(objToIndex.GetType(), objToObj);
}
else
{
objToObj = _mergeObjDict[objToIndex.GetType()];
}
if (!objToObj.ContainsKey(key))
{
objToObj.Add(key, objToIndex);
}
else
{
return objToObj[key] as T;
}
return null as T;
};
return func(act);
}
}
}
现在所有这些都按预期正常工作,它成功地将所有已实现的属性复制到域模型/接口(interface)或从域模型/接口(interface)复制。
我现在正尝试使用 IQueryable 和延迟加载。
我现在正在做这个
dbContext.Roles.Select((x)=> x.CopyTo<RolesPoco>());
我想看看是否有一种方法可以自动生成包含,例如
dbContext.Roles.Select((x)=> x.Users.Include((y)=> y.someSubEntity);
我也想看看我是否可以加入一些像这样的 where 子句
//the first string is a path so something like "Roles.Users.someSubEntity"
//the second string is a IQueryable function like Where or Take
Dictionary<String,Dictionary<String,List<Func<T, IQueryable<TProperty>>>> queryDict
dbContext.Roles.Select((x)=> x.CopyTo<RolesPoco>(queryDict)
然后 List 将是一些可以在 include 函数内部运行的 lambda 列表。有人对此有任何想法吗?
编辑:我重构并简化了一些代码,这样即使类没有实现接口(interface),它也可以调用 getter/setter。因此,无论是否存在支持字段,都可以访问属性。如果未定义,则返回 null。
Edit2:由于似乎不清楚我要实现的目标,让我澄清一下。如果您查看此 msdn page 的备注部分,您会看到一些选择语句。我想生成这些表达式,然后根据要复制到的类是否包含实现该成员的接口(interface),在父选择中使用它们。我避免使用 linqToObject,因为我只需要在 CopyTo 中定义的属性,但导航属性是接口(interface),这会破坏 Entity Framework 。这是为了延迟加载目的。 MergeStack 将组合这些表达式并将其返回到树中。我的想法来自 a DaedTech blogpost
最佳答案
Roles 是 IQueryable,因此您需要从 Queryable 扩展类中获取 Select 方法。您还需要从 Enumerable 扩展类中获取 Include。然后,您需要使用 Role 作为通用参数来调用 Select 方法。您需要使用 Expression.Lambda、Expression.Call 和 Expression.Property 构造一个 lambda。
关于c# - 带有poco生成的 Entity Framework IQueryable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21565703/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!