C#实现根据实体类自动创建数据库表
.Net新手通常容易把属性(Property)跟特性(Attribute)搞混,其实这是两种不同的东西
属性指的类中封装的数据字段;而特性是对类、字段、方法和属性等元素标注的声明性信息
如下代码(Id、Name为User的属性,[DbKey]为Id的特性)
///<summary>
///用户信息
///</summary>
publicclassUser
{
[DbKey]
publicstringId{get;set;}
publicstringName{get;set;}
}
特性分预定义特性和自定义特性,本节主要讲述自定义特性
特性能解决什么问题?
假如现在需要通过定义一些实体类,动态创建出对应的数据库表,该怎么做呢?
直接上代码
namespaceCustomerAttribute
{
///<summary>
///数据库主键
///</summary>
publicclassDbKey:Attribute
{
publicstringDescription{get;set;}
publicDbKey()
{
}
publicDbKey(stringdescription)
{
this.Description=description;
}
}
}
namespaceCustomerAttribute
{
///<summary>
///用户信息
///</summary>
publicclassUser
{
[DbKey]
publicstringId{get;set;}
publicstringName{get;set;}
}
///<summary>
///用户角色
///</summary>
publicclassUserRole
{
[DbKey("用户ID")]
publicstringUserId{get;set;}
[DbKey("角色ID")]
publicstringRoleId{get;set;}
}
}
namespaceCustomerAttribute
{
classProgram
{
///<summary>
///获取数据库主键字段
///</summary>
///<typeparamname="T"></typeparam>
///<returns></returns>
privatestaticIEnumerable<PropertyInfo>getDbKeyFields<T>()
{
//获取当前类中的公共字段
varfields=typeof(T).GetProperties();
//查找有DbKey特性的字段
varkeyFields=fields.Where(field=>(DbKey)Attribute.GetCustomAttribute(field,typeof(DbKey))!=null);
returnkeyFields;
}
privatestaticstringgetDescription(PropertyInfofield)
{
stringresult=string.Empty;
vardbKey=(DbKey)Attribute.GetCustomAttribute(field,typeof(DbKey));
if(dbKey!=null)result=dbKey.Description;
returnresult;
}
staticvoidMain(string[]args)
{
try
{
varuserKeyFields=getDbKeyFields<User>();
Console.WriteLine("User表的主键为:"+string.Join(",",userKeyFields.Select(field=>field.Name)));
varuserRoleKeyFields=getDbKeyFields<UserRole>();
Console.WriteLine("UserRole表的主键为:"+string.Join(",",userRoleKeyFields.Select(field=>field.Name)));
foreach(PropertyInfofieldinuserRoleKeyFields)
{
stringdescription=getDescription(field);
Console.WriteLine(string.Format("{0}字段的描述信息为:{1}",field.Name,description));
}
}
catch(Exceptionex)
{
Console.WriteLine(ex);
}
finally
{
Console.ReadLine();
}
}
}
}
从上边代码可以看出来,特性本身也是类,继承自Attribute类,我们可以对类、方法、属性等元素进行特性标注
上边是一个简单示例,我们可以通过自定义[DbKey]特性,标注在需要设置主键的字段上
需要动态创建数据库的时候,可以从实体类中解析出表名、字段名、主键字段、字段说明等等,然后生成创建数据库表的脚本,动态创建数据库表
创建数据库的代码,后边可以进一步补充
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持毛票票!