public IDictionary <string, object> GetOwnerDynamic( OwnerQueryRow row, OwnerQueryProjection projection, OwnerQueryOptions options) { var obj = new Dictionary <string, object>(); foreach (var f in projection.GetFieldsArr()) { switch (f) { case OwnerQueryProjection.INFO: { var entity = row.Owner; obj["id"] = entity.Id; obj["code"] = entity.Code; obj["name"] = entity.Name; obj["phone"] = entity.Phone; obj["description"] = entity.Description; obj["archived"] = entity.Archived; } break; case OwnerQueryProjection.SELECT: { var entity = row.Owner; obj["id"] = entity.Id; obj["code"] = entity.Code; obj["name"] = entity.Name; } break; } } return(obj); }
public static DynamicSql SqlProjectFields( this DynamicSql query, OwnerQueryProjection model) { query = DynamicSql.DeepClone(query); var finalFields = model.GetFieldsArr() .Where(f => OwnerQueryProjection.Projections.ContainsKey(f)) .Select(f => OwnerQueryProjection.Projections[f]); if (finalFields.Any()) { var projectionClause = string.Join(',', finalFields); query.DynamicForm = query.DynamicForm .Replace(DynamicSql.PROJECTION, projectionClause); } var finalResults = model.GetFieldsArr() .Where(f => OwnerQueryProjection.Results.ContainsKey(f)) .Select(f => OwnerQueryProjection.Results[f]); query.MultiResults.AddRange(finalResults); return(query); }
public static DynamicSql SqlJoin( this DynamicSql query, OwnerQueryProjection model) { query = DynamicSql.DeepClone(query); var joins = model.GetFieldsArr() .Where(f => OwnerQueryProjection.Joins.ContainsKey(f)) .Select(f => OwnerQueryProjection.Joins[f]); if (joins.Any()) { var joinClause = string.Join('\n', joins); query.DynamicForm = query.DynamicForm .Replace(DynamicSql.JOIN, joinClause); } return(query); }