Csharp/C#教程: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]特性,标注在需要设置主键的字段上

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

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

您可能感兴趣的文章:C#实现实体类和XML相互转换C#实现XML与实体类之间相互转换的方法(序列化与反序列化)C#实现实体类与字符串互相转换的方法c#DataTable与不同结构实体类转换的方法实例C#DataTable转换为实体类对象实例c#对象反序列化与对象序列化示例详解C#对象与XMl文件之间的相互转换C#判等对象是否相等的方法汇总浅谈对c#面向对象的理解C#面向对象的基本原则C#编程获取实体类属性名和值的方法示例

标签: 数据库 实体类 实体 数据 自动

详解二维码生成工厂

C#中abstract的用法详解

上述就是C#学习教程:C#实现根据实体类自动创建数据库表分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/907633.html

(0)
上一篇 2021年10月24日
下一篇 2021年10月24日

精彩推荐