发布1212
大石头 编写于 2019-12-12 23:38:12
X
using System;
using System.Collections.Generic;

namespace XCode.DataAccessLayer
{
    /// <summary>数据表</summary>
    public interface IDataTable : ICloneable
    {
        #region 属性
        /// <summary>名称</summary>
        String Name { get; set; }

        /// <summary>表名</summary>
        String TableName { get; set; }

        /// <summary>基类</summary>
        String BaseType { get; set; }

        /// <summary>所有者</summary>
        String Owner { get; set; }

        /// <summary>连接名</summary>
        String ConnName { get; set; }

        /// <summary>
        /// 数据库类型。
        /// 仅用于记录实体类由何种类型数据库生成,当且仅当目标数据库同为该数据库类型时,采用实体属性信息上的RawType作为反向工程的目标字段类型,以期获得开发和生产的最佳兼容。
        /// </summary>
        DatabaseType DbType { get; set; }

        /// <summary>是否视图</summary>
        Boolean IsView { get; set; }

        /// <summary>显示名。如果有Description则使用Description,否则使用Name</summary>
        String DisplayName { get; }

        /// <summary>说明</summary>
        String Description { get; set; }

        /// <summary>仅插入的日志型数据</summary>
        Boolean InsertOnly { get; set; }

        /// <summary>忽略表名/字段名大小写</summary>
        String NameIgnoreCase { get; set; }
        #endregion

        #region 扩展属性
        /// <summary>数据列集合。可以是空集合,但不能为null。</summary>
        List<IDataColumn> Columns { get; }

        /// <summary>数据索引集合。可以是空集合,但不能为null。</summary>
        List<IDataIndex> Indexes { get; }

        /// <summary>主键集合。可以是空集合,但不能为null。</summary>
        IDataColumn[] PrimaryKeys { get; }

        /// <summary>主字段。主字段作为业务主要字段,代表当前数据行意义</summary>
        IDataColumn Master { get; }

        /// <summary>扩展属性</summary>
        IDictionary<String, String> Properties { get; }
        #endregion

        #region 方法
        /// <summary>创建数据列</summary>
        /// <returns></returns>
        IDataColumn CreateColumn();

        /// <summary>创建数据索引</summary>
        /// <returns></returns>
        IDataIndex CreateIndex();

        /// <summary>修正数据</summary>
        IDataTable Fix();
        #endregion
    }
}