【问题标题】:Dynamic Data Site: can't hide a table动态数据站点:无法隐藏表格
【发布时间】:2025-12-15 11:25:03
【问题描述】:

我创建了基于“动态数据站点”模板的新网站。向其中添加了 3 个表:Product、ProductSKU、SkuPrice。表之间有关系:

Product.ProdId=ProductSku.ProdId
ProductSku.SkuId=SkuPrice.SkuId

我不希望用户看到“产品”表,所以我隐藏了该表:

namespace CompanyDbAdmin
{
    [MetadataType(typeof(ProductMetadata))]
    public partial class Product
    {
    }

    [ScaffoldTable(false)]
    public class ProductMetadata
    {    
    }
}

当我试图隐藏“ProductSKU”表中的某些列时:

namespace CompanyDbAdmin
{
    [MetadataType(typeof(ProductSKUMetadata))]
    public partial class ProductSKU
    {
    }

    public class ProductSKUMetadata
    {
        [ScaffoldColumn(false)]
        public object MyCollumnName { get; set; }
    }
}

我发现这不起作用:列仍然显示。问题似乎是“ProductSKU”类与现有表不“匹配”......

这是该表的自动生成代码:

namespace CompanyDbAdmin
{

    /// <summary>
    /// No Metadata Documentation available.
    /// </summary>
    [EdmEntityTypeAttribute(NamespaceName="SotiModel", Name="ProductSKU")]
    [Serializable()]
    [DataContractAttribute(IsReference=true)]
    public partial class ProductSKU : EntityObject
    {
        ....
    }
}

尝试隐藏此表

namespace CompanyDbAdmin
{
    [MetadataType(typeof(ProductSKUMetadata))]
    public partial class ProductSKU
    {
    }

    [ScaffoldTable(false)]
    public class ProductSKUMetadata
    {
        [ScaffoldColumn(false)]
        public object MyCollumnName { get; set; }
    }
}

也不起作用:表格仍然存在于第一页...

为什么?如何解决?

非常感谢!

【问题讨论】:

  • 如果将ScaffoldTable(false) 直接放在ProductSKU 类上会发生什么?
  • 没试过。这有意义吗?

标签: asp.net entity-framework dynamic-data asp.net-dynamic-data


【解决方案1】:

该问题的解决方案:Partial class doesn't match to auto-generated class part 也解决了当前问题

附:实际上,我的链接答案已被版主删除(不知道为什么),但问题出在 VS 中:它没有将实体类视为部分......因此没有将元数据类应用于实体类。

【讨论】: