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