C#实现根据实体类自动创建数据库表

作者:天碼行空 时间:2024-01-12 13:23:29 

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

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

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


/// <summary>
/// 用户信息
/// </summary>
public class User
{
[DbKey]
public string Id { get; set; }
public string Name { get; set; }
}

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

特性能解决什么问题?

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

直接上代码


namespace CustomerAttribute
{
/// <summary>
/// 数据库主键
/// </summary>
public class DbKey : Attribute
{
public string Description { get; set; }
public DbKey()
{
}
public DbKey(string description)
{
this.Description = description;
}
}
}

namespace CustomerAttribute
{
/// <summary>
/// 用户信息
/// </summary>
public class User
{
[DbKey]
public string Id { get; set; }
public string Name { get; set; }
}
/// <summary>
/// 用户角色
/// </summary>
public class UserRole
{
[DbKey("用户ID")]
public string UserId { get; set; }
[DbKey("角色ID")]
public string RoleId { get; set; }
}
}

namespace CustomerAttribute
{
class Program
{
/// <summary>
/// 获取数据库主键字段
/// </summary>
/// <typeparam name="T"></typeparam>
/// <returns></returns>
private static IEnumerable<PropertyInfo> getDbKeyFields<T>()
{
// 获取当前类中的公共字段
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<User>();
Console.WriteLine("User表的主键为:" + string.Join(",", userKeyFields.Select(field => field.Name)));
var userRoleKeyFields = getDbKeyFields<UserRole>();
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]特性,标注在需要设置主键的字段上

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

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

来源:http://www.cnblogs.com/jh007/p/6124179.html

标签:C#,实体类,数据库表
0
投稿

猜你喜欢

  • Golang中的int类型和uint类型到底有多大?

    2024-04-25 15:04:44
  • Python3实现取图片中特定的像素替换指定的颜色示例

    2022-08-31 15:33:21
  • HTML5 移动页面自适应手机屏幕宽度详解

    2022-08-14 23:14:43
  • 基于plt.title无法显示中文的快速解决

    2023-06-17 10:16:27
  • spyder常用快捷键(分享)

    2021-04-01 16:18:17
  • 用python实现爬取奥特曼图片实例

    2022-09-23 00:25:18
  • python实现用于测试网站访问速率的方法

    2023-07-28 19:12:02
  • SQL查询语句优化的实用方法总结

    2024-01-25 18:51:21
  • 一文搞懂Vue3中的异步组件defineAsyncComponentAPI的用法

    2024-04-29 13:09:08
  • Python namedtuple命名元组实现过程解析

    2022-08-20 14:27:20
  • 详解Google Protobuf简明教程

    2023-08-17 14:47:28
  • Python 爬虫之超链接 url中含有中文出错及解决办法

    2023-07-27 00:25:06
  • js中bool值的转换及“&&”、“||”、 “!!”详解

    2024-04-19 10:02:01
  • 排序与检索

    2008-05-18 13:09:00
  • python对excel文档去重及求和的实例

    2021-09-30 03:30:35
  • 利用Python将彩色图像转为灰度图像的两种方法

    2021-02-06 05:28:54
  • OpenCV搞定腾讯滑块验证码的实现代码

    2022-09-09 21:41:04
  • Oracle AS关键字 提示错误

    2011-04-18 12:42:00
  • Python基础详解之邮件处理

    2021-03-16 09:27:58
  • Python实现的用户登录系统功能示例

    2021-07-02 03:38:18
  • asp之家 网络编程 m.aspxhome.com