Пример #1
0
        public DeserializeHelper(string tableName, string fields)
        {
            this.Highlight  = null;
            this._TableName = tableName;
            if (fields == "*" || string.IsNullOrWhiteSpace(fields))
            {
                fields = "";
            }
            this._Fields = fields;
            string[] source = fields.ToLower().Split(new char[]
            {
                ','
            }, StringSplitOptions.RemoveEmptyEntries);
            Type typeFromHandle = typeof(T);

            PropertyInfo[] properties = typeFromHandle.GetProperties();
            for (int i = 0; i < properties.Length; i++)
            {
                PropertyInfo        propertyInfo        = properties[i];
                PrimaryKeyAttribute primaryKeyAttribute = PrimaryKeyHelper.GetPrimaryKeyAttribute(propertyInfo);
                if (primaryKeyAttribute != null)
                {
                    this.PrimaryKey = primaryKeyAttribute;
                }
                if (string.IsNullOrWhiteSpace(fields) || source.Contains(propertyInfo.Name.ToLower()))
                {
                    this._PropertyList.Add(propertyInfo);
                }
            }
            if (!string.IsNullOrWhiteSpace(this._TableName))
            {
                this._DataTableSchema = new DataTable(this._TableName);
            }
            else
            {
                this._DataTableSchema = new DataTable("QueryData");
            }
            foreach (PropertyInfo current in this.PropertyList)
            {
                DataColumn column = new DataColumn(current.Name, current.PropertyType);
                this._DataTableSchema.Columns.Add(column);
            }
            if (!string.IsNullOrWhiteSpace(this._Fields))
            {
                if (source.Contains("score"))
                {
                    DataColumn column2 = new DataColumn("score", typeof(double));
                    this._DataTableSchema.Columns.Add(column2);
                }
                if (source.Contains("_version_"))
                {
                    DataColumn column3 = new DataColumn("_version_", typeof(string));
                    this._DataTableSchema.Columns.Add(column3);
                }
            }
        }