说说底层架构之实体类的设计

简介:

今天有点时间,来说说如何设计的实体类更加合理,灵活,规范.

首先,那要和真实数据表一一对应,必要的话,可以对类型抽象化,可以引入枚举,泛型列表等类型;其次,对实体要集成它的数据有效性的验证功能;再次,为了数据操作方便,有必要去引入数据表字段的列举集合;综上所述,我们来设计一个用户表实体;

本例中的知识点为:部分类,接口规范,Flag属性的枚举,迭代器等

     /// <summary>
    /// 数据实体统一接口
    /// </summary>
    public interface IDataEntity
    {
    }

     /// <summary>
    /// 用户实体
    /// </summary>
    partial class UserBase : IDataEntity
    {
        public string UserName { get; set; }
        public int Age { get; set; }
    }
     /// <summary>
    /// 实体验证类
    /// </summary>
    public class RuleViolation
    {
        /// <summary>
        /// 错误属性
        /// </summary>
        public string ErrProperty { get; private set; }
        /// <summary>
        /// 错误信息
        /// </summary>
        public string ErrMessage { get; private set; }
        public RuleViolation(string errProperty, string errMessage)
        {
            this.ErrProperty = errProperty;
            this.ErrMessage = errMessage;
        }
        public RuleViolation(string errMessage)
            : this(errMessage, null)
        {
 
        }
    }
    /// <summary>
    /// 实体验证统一接口
    /// </summary>
    public interface IEntity
    {
        /// <summary>
        /// 验证是否通过
        /// </summary>
        bool IsValid { get; }
        /// <summary>
        /// 以迭代的形式返回验证列表
        /// </summary>
        /// <returns></returns>
        IEnumerable<RuleViolation> GetRuleViolations();
    }
     /// <summary>
    /// 用户实体验证
    /// </summary>
    public partial class UserBase : IEntity
    {
 
        #region IEntity Members
 
        public bool IsValid
        {
            get { return this.GetRuleViolations().Count() == 0; }
        }
 
        public IEnumerable<RuleViolation> GetRuleViolations()
        {
            if (string.IsNullOrEmpty(this.UserName))
                yield return new RuleViolation("UserName", "用户名为能为空");
            if (this.Age == 0)
                yield return new RuleViolation("Age", "没有年龄为0的数据,至少为1");
        }
 
        #endregion
    }
     /// <summary>
    /// 表字段列举
    /// </summary>
    [Flags]
    public enum UserBaseColumns
    {
        UserName = 1,
        Age = 2,
    }
 
目录
相关文章
|
22天前
|
SQL druid Java
JDBC技术【分页查询、数据库连接池、应用程序分层、封装通用的BaseDao】(四)-全面详解(学习总结---从入门到深化)(上)
JDBC技术【分页查询、数据库连接池、应用程序分层、封装通用的BaseDao】(四)-全面详解(学习总结---从入门到深化)
87 0
|
22天前
|
Java
java面向对象高级分层实例_实体类
java面向对象高级分层实例_实体类
13 1
|
22天前
|
SQL 设计模式 Java
【软件工程底层逻辑系列】建模的底层逻辑
在本文中,给出建模的底层逻辑:用图形逻辑地表达现实业务的抽象,通过一些大家通识的技术案例讲述建模的过程。
74904 3
|
22天前
|
Java 数据库
java面向对象高级分层实例_数据库操作类
java面向对象高级分层实例_数据库操作类
13 1
|
22天前
|
SQL druid Java
JDBC技术【分页查询、数据库连接池、应用程序分层、封装通用的BaseDao】(四)-全面详解(学习总结---从入门到深化)
JDBC技术【分页查询、数据库连接池、应用程序分层、封装通用的BaseDao】(四)-全面详解(学习总结---从入门到深化)
35 0
|
22天前
|
SQL Java 数据库连接
JDBC技术【分页查询、数据库连接池、应用程序分层、封装通用的BaseDao】(四)-全面详解(学习总结---从入门到深化)(下)
JDBC技术【分页查询、数据库连接池、应用程序分层、封装通用的BaseDao】(四)-全面详解(学习总结---从入门到深化)
465 1
|
22天前
|
SQL Java 数据库连接
JDBC技术【分页查询、数据库连接池、应用程序分层、封装通用的BaseDao】(四)-全面详解(学习总结---从入门到深化)(中)
JDBC技术【分页查询、数据库连接池、应用程序分层、封装通用的BaseDao】(四)-全面详解(学习总结---从入门到深化)
32 0
|
12月前
|
设计模式 Linux C++
C++ 接口和实现分离初步简介
C++ 接口和实现分离初步简介
128 0
|
芯片
驱动设计思想_面向对象_分层_分离
驱动设计思想_面向对象_分层_分离
132 0
|
数据库 开发者
业务层设计与开发(业务层标准实现类) | 学习笔记
简介:快速学习业务层设计与开发(业务层标准实现类)
103 0

热门文章

最新文章