专业网站建设品牌,十四年专业建站经验,服务6000+客户--广州京杭网络
免费热线:400-683-0016      微信咨询  |  联系我们

关系映射配置—Table属性

当前位置:网站建设 > 技术支持
资料来源:网络整理       时间:2023/2/14 0:10:37       共计:3641 浏览

在上一篇随笔中已经完成了ADO.NET操作数据库的封装,并已经支持多数据库,只需要在配置文件中指定数据库类型即可,本节主要完成对象与数据库表的关系映射配置。

下面看表名的映射配置代码块1-1:

[Table(Name="Student")] public class StudentEntity
{ //...........省略 }

在类上面用[Table(name = ”Student")]属性来配置,表示该实体类StudentEntity与数据库中的Student表进行关系映射。 

Table属性需要自己编写,代码块1-2:

using System; using System.Collections.Generic; using System.Text; namespace System.Orm.CustomAttributes
{
    [AttributeUsage(AttributeTargets.Class, AllowMultiple = false, Inherited = false)] public class TableAttribute : Attribute { private string _Name = string.Empty; public TableAttribute() {} public string Name
        { get { return _Name; } set { _Name = value; }
        }
    }
}

    上面代码中我们编写TableAttribute自定义属性类,然后继承Attribute自定义属性基类,在具体使用的时候我们只需在需要配置属性的类上加[Table(Name="你要指定的表名")]。这里的TableAttribute省略了后面的Attribute,用Table即可.NET会根据Table名称+Atrribute去查找TableAttribute类。

[AttributeUsage(AttributeTargets.Class, AllowMultiple = false, Inherited = false)]

    这段属性配置表示TableAttribute属性类的用法配置,

AttributeTargets.Class表示只可用于类,所以使用时把该属性加载类的上面,如代码块1-1

AllowMultiple 表示能否为一个元素指定多个属性示例,在这里比如在StudentEntity上是否可以配置多次Table属性,我们设置false即只可配置一次。

Inherited 表示Table属性可否被继承,这里设置false即不可被继承。

    在TableAttribute属性类中定义了Name公有属性,用于指定Table属性所配置的实体所对应的数据库中表名。

这里Table属性到这里已经完成,下一篇中将继续介绍自定义属性:

IdAttribute  (用于指定实体类中哪一个属性字段对应数据库表中的主键ID)

版权说明:
本网站凡注明“广州京杭 原创”的皆为本站原创文章,如需转载请注明出处!
本网转载皆注明出处,遵循行业规范,如发现作品内容版权或其它问题的,请与我们联系处理!
欢迎扫描右侧微信二维码与我们联系。
·上一条:AdoHelper支持多数据库操作的封装(2) | ·下一条:关系映射配置—Id属性 ORM

Copyright © 广州京杭网络科技有限公司 2005-2024 版权所有    粤ICP备16019765号 

广州京杭网络科技有限公司 版权所有