Example #1
0
        public TModel ToSingle()
        {
            var sqlString  = Builder.ToString();
            var parameters = Builder.GetParameters();

            using (var reader = Session.QueryReader(sqlString, parameters.ToArray()))
            {
                if (reader.Read())
                {
                    var model = new TModel();

                    var properties = ReflectionHelper.AllProperty(typeof(TModel), ReflectionHelper.DefBindingFlags | BindingFlags.DeclaredOnly);
                    foreach (var property in properties)
                    {
                        var aliasName = Resolver.ResolveAliasName <TModel>(property.Member);
                        if (!Builder.HasColumn(aliasName))
                        {
                            continue;
                        }
                        var index = reader.GetOrdinal(aliasName);
                        if (reader.IsDBNull(index))
                        {
                            continue;
                        }
                        var value = reader.GetValue(index);
                        property.SetValue(model, value);
                    }

                    return(model);
                }
            }
            return(null);
        }
Example #2
0
        public IDbQuery <TModel> Select(Func <TModel, object> expression)
        {
            if (expression == null)
            {
                throw new ArgumentNullException("expression");
            }
            var model      = expression(new TModel());
            var properties = ReflectionHelper.AllProperty(model.GetType(), ReflectionHelper.DefBindingFlags | BindingFlags.DeclaredOnly);

            if (properties.Count == 0)
            {
                throw new NotImplementedException();
            }

            var modelType      = typeof(TModel);
            var tableName      = modelType.Name;
            var tableAliasName = Resolver.ResolveAliasName <TModel>(modelType);

            Builder.Dispose();
            Builder.Add("SELECT");
            Builder.Add(" ");
            var index = 0;

            foreach (var property in properties)
            {
                var aliasName = Resolver.ResolveAliasName <TModel>(property.Member);
                if (tableName != tableAliasName)
                {
                    Builder.Add(tableAliasName).Add(".");
                }
                if (aliasName != property.Name)
                {
                    Builder.Add(" AS [").AddColumn(aliasName).Add("]");
                }
                else
                {
                    Builder.AddColumn(property.Name);
                }
                if (index != properties.Count - 1)
                {
                    Builder.Add(",");
                }
                index++;
            }
            Builder.Add(" ");
            Builder.Add("FORM ");
            Builder.Add(tableName);
            if (tableName != tableAliasName)
            {
                Builder.Add(" AS ").Add(tableAliasName);
            }
            return(this);
        }
Example #3
0
        public IList <TModel> ToList()
        {
            var sqlString  = Builder.ToString();
            var parameters = Builder.GetParameters();

            var dt = Session.Query(sqlString, parameters.ToArray());

            if (dt.Rows.Count == 0)
            {
                return(null);
            }

            var list       = new List <TModel>();
            var properties = ReflectionHelper.AllProperty(typeof(TModel), ReflectionHelper.DefBindingFlags | BindingFlags.DeclaredOnly);

            foreach (DataRow row in dt.Rows)
            {
                var model = new TModel();
                foreach (var property in properties)
                {
                    var aliasName = Resolver.ResolveAliasName <TModel>(property.Member);
                    if (!Builder.HasColumn(aliasName))
                    {
                        continue;
                    }
                    var value = row[aliasName];
                    if (value == DBNull.Value || value == null)
                    {
                        continue;
                    }
                    property.SetValue(model, value);
                }
                list.Add(model);
            }
            return(list);
        }