c# - 为什么在MVC中调用GetType Name得到的是一组数字?

标签 c# asp.net-mvc entity-framework asp.net-mvc-4

我正在使用 c# Asp.net MVC。我有一个 TPH 模型,所以我调用 GetType().Name 来找出正在使用的类类型。但有时当我调用 GetType().Name 时,我不仅得到模型的名称,而且得到它后面的一大串数字。为什么会发生这种情况,我该如何避免这种情况?

例子

public string DiscriminatorValue
{
    get{ return this.GetType.Name;
}
//...
RedirectToAction("Index", 
                 "Files", 
                  new { itemId = vm.itemid, 
                        itemtype = vm.item.DiscriminatorValue.ToString()});

得到这个:

DiscriminatorActualValue_D808C81C7BDE227500B30C6760AC934EA4A1307BD88500694065B3389D2642B1

最佳答案

这是因为您在 Entity 框架为您创建的代理类型上调用该方法。

您可以在此处阅读有关代理的信息:http://msdn.microsoft.com/en-us/data/jj592886.aspx 在那里(最后)你也有如何获得实际类型的解释(这解决了你的问题)

引用上面的链接:

从代理类型获取实际的实体类型

代理类型的名称看起来像这样: System.Data.Entity.DynamicProxies .Blog_5E43C6C196972BF0754973E48C9C941092D86818CD94005E9A759B70BF6E48E6

您可以使用 ObjectContext 中的 GetObjectType 方法找到此代理类型的实体类型。例如:

using (var context = new BloggingContext())
{
    var blog = context.Blogs.Find(1);
    var entityType = ObjectContext.GetObjectType(blog.GetType());
}

关于c# - 为什么在MVC中调用GetType Name得到的是一组数字?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20475788/

相关文章:

mysql - 将 Oracle/MySQL 与 .NET Entity Framework 结合使用有什么更好的方法吗?

c# - CompiledQuery.Compile 需要锁(EF4、SQL Server、C#)

c# - ASP.Net MVC 将标签值回发到您的 Controller

c# - 为什么我在用户 "Server"垃圾回收时会出现内存泄漏?

c# - 更具体/更强的 MemberExpression 用于编译时检查?

c# - 使用多个提交按钮

c# - if block 内的标签和@model

c# - 使用 System.Drawing 绘制文本时出现低分辨率图像

c# - 并行线程中的多个 dbcontext,EntityException "Rerun your statement when there are fewer active users"

c# - 在 C# 中使用多线程的正确方法