winform mysql 建表_C#实现根据实体类自动创建数据库表

这篇博客介绍了如何使用C#和特性(Attribute)来动态创建MySQL数据库表。通过定义自定义特性[DbKey],标记类中的主键字段,然后解析实体类获取表名、字段信息,从而生成建表脚本。示例代码展示了如何获取带有[DbKey]特性的字段及其描述信息,为动态数据库建表提供了一种解决方案。
摘要由CSDN通过智能技术生成

.Net新手通常容易把属性(Property)跟特性(Attribute)搞混,其实这是两种不同的东西

属性指的类中封装的数据字段;而特性是对类、字段、方法和属性等元素标注的声明性信息

如下代码(Id、Name为User的属性,[DbKey]为Id的特性)

///

/// 用户信息

///

public class User

{

[DbKey]

public string Id { get; set; }

public string Name { get; set; }

}

特性分预定义特性和自定义特性,本节主要讲述自定义特性

特性能解决什么问题?

假如现在需要通过定义一些实体类,动态创建出对应的数据库表,该怎么做呢?

直接上代码

namespace CustomerAttribute

{

///

/// 数据库主键

///

public class DbKey : Attribute

{

public string Description { get; set; }

public DbKey()

{

}

public DbKey(string description)

{

this.Description = description;

}

}

}

namespace CustomerAttribute

{

///

/// 用户信息

///

public class User

{

[DbKey]

public string Id { get; set; }

public string Name { get; set; }

}

///

/// 用户角色

///

public class UserRole

{

[DbKey("用户ID")]

public string UserId { get; set; }

[DbKey("角色ID")]

public string RoleId { get; set; }

}

}

namespace CustomerAttribute

{

class Program

{

///

/// 获取数据库主键字段

///

///

///

private static IEnumerable getDbKeyFields()

{

// 获取当前类中的公共字段

var fields = typeof(T).GetProperties();

// 查找有DbKey特性的字段

var keyFields = fields.Where(field => (DbKey)Attribute.GetCustomAttribute(field, typeof(DbKey)) != null);

return keyFields;

}

private static string getDescription(PropertyInfo field)

{

string result = string.Empty;

var dbKey = (DbKey)Attribute.GetCustomAttribute(field, typeof(DbKey));

if (dbKey != null) result = dbKey.Description;

return result;

}

static void Main(string[] args)

{

try

{

var userKeyFields = getDbKeyFields();

Console.WriteLine("User表的主键为:" + string.Join(",", userKeyFields.Select(field => field.Name)));

var userRoleKeyFields = getDbKeyFields();

Console.WriteLine("UserRole表的主键为:" + string.Join(",", userRoleKeyFields.Select(field => field.Name)));

foreach (PropertyInfo field in userRoleKeyFields)

{

string description = getDescription(field);

Console.WriteLine(string.Format("{0}字段的描述信息为:{1}", field.Name, description));

}

}

catch (Exception ex)

{

Console.WriteLine(ex);

}

finally

{

Console.ReadLine();

}

}

}

}

从上边代码可以看出来,特性本身也是类,继承自Attribute类,我们可以对类、方法、属性等元素进行特性标注

上边是一个简单示例,我们可以通过自定义[DbKey]特性,标注在需要设置主键的字段上

需要动态创建数据库的时候,可以从实体类中解析出表名、字段名、主键字段、字段说明等等,然后生成创建数据库表的脚本,动态创建数据库表

创建数据库的代码,后边可以进一步补充

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值