有没有办法可以像这样生成代码文件:
public partial class A {
public string a {get; set;}
}
然后在另一个文件中:
public partial class A {
[Attribute("etc")]
public string a {get; set;}
}
这样我可以从数据库生成一个类,然后使用非生成的文件来标记它?
答案 0 :(得分:62)
这是我一直用于此类案例的解决方案。当您想要使用属性装饰自动生成的类时,它非常有用。假设这是自动生成的类:
public partial class UserProfile
{
public int UserId { get; set; }
public string UserName { get; set; }
public string Firstname { get; set; }
public string Lastname { get; set; }
}
让我们说,我想添加一个属性来指定UserId是关键。然后我会在另一个文件中创建一个部分类,如下所示:
[Table("UserProfile")]
[MetadataType(typeof(UserProfileMetadata))]
public partial class UserProfile
{
internal sealed class UserProfileMetadata
{
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int UserId { get; set; }
}
}
答案 1 :(得分:29)
我在斯科特·格思里(Scott Guthrie)的一篇文章中看到过这样的事情(接近尾声) - 不过我自己也没试过。 http://weblogs.asp.net/scottgu/archive/2010/01/15/asp-net-mvc-2-model-validation.aspx
[MetadataType(typeof(Person_Validation))]
public partial class Person
{
// Partial class compiled with code produced by VS designer
}
[Bind(Exclude="ID")]
public class Person_Validation
{
[Required(ErrorMessage = "First Name Required")]
[StringLength(50, ErrorMessage = "Must be under 50 characters")]
public string FirstName { get; set; }
[Required(ErrorMessage = "Last Name Required")]
[StringLength(50, ErrorMessage = "Must be under 50 characters")]
public string LastName { get; set; }
[Required(ErrorMessage = "Age Required")]
[Range(0, 120, ErrorMessage = "Age must be between 0 and 120")]
public int Age { get; set; }
[Required(ErrorMessage = "Email Required")]
[Email(ErrorMessage = "Not a valid email")]
public string Email { get; set; }
}
答案 2 :(得分:2)
这是我的答案
不同的类文件或者你可以将metadatas组合在同一个文件中,但保持名称空间相同......所以他们可以明显地看到对方。
在更新模型时请记住,例如添加更多列,您也必须更新项目类。
--your model class
public partial class A {
public string a {get; set;}
}
--your project class
public class Ametadata {
[Attribute("etc")]
public string a {get; set;}
}
[MetadataType(typeof(Ametadata))]
public partial class A
{
}
答案 3 :(得分:1)
您需要为A
类定义一个部分类,就像下面的示例
using System.ComponentModel.DataAnnotations;
// your auto-generated partial class
public partial class A
{
public string MyProp { get; set; }
}
[MetadataType(typeof(AMetaData))]
public partial class A
{
}
public class AMetaData
{
[System.ComponentModel.DefaultValue(0)]
public string MyProp { get; set; }
}
答案 4 :(得分:0)
不是这样;编译器会抱怨该成员是在多个部分中定义的。但是,由于自定义属性的使用本质上是反射性的,因此您可以定义“元数据”类并使用它来包含装饰器。
public class A
{
public string MyString;
}
public class AMeta
{
[TheAttribute("etc")]
public object MyString;
}
...
var myA = new A();
var metaType = Type.GetType(myA.GetType().Name + "Meta");
var attributesOfMyString = metaType.GetMember("MyString").GetCustomAttributes();