コード例 #1
0
        public static string GetSelectFields(System.Type type, ISqlBuilder builder, params string[] ignorProperties)
        {
            ORMappingItemCollection mapping = InnerGetMappingInfo(type);

            SelectSqlClauseBuilder selectBuilder = GetSelectSqlClauseBuilder(false, mapping, ignorProperties);

            return(selectBuilder.ToSqlString(TSqlBuilder.Instance));
        }
コード例 #2
0
        private static string GetSelectSql(bool useTableName, ORMappingItemCollection mapping, ISqlBuilder builder, string[] ignorProperties)
        {
            ExceptionHelper.FalseThrow <ArgumentNullException>(mapping != null, "mapping");
            ExceptionHelper.FalseThrow <ArgumentNullException>(builder != null, "builder");

            SelectSqlClauseBuilder selectBuilder = GetSelectSqlClauseBuilder(useTableName, mapping, ignorProperties);

            return(string.Format("SELECT {0} FROM {1} ", selectBuilder.ToSqlString(builder), mapping.TableName));
        }
コード例 #3
0
        private static SelectSqlClauseBuilder GetSelectSqlClauseBuilder(bool useTableName, ORMappingItemCollection mapping, params string[] ignorProperties)
        {
            ExceptionHelper.FalseThrow <ArgumentNullException>(mapping != null, "mapping");

            SelectSqlClauseBuilder builder = new SelectSqlClauseBuilder();

            if (useTableName)
            {
                builder.TableName = mapping.TableName;
            }
            FillSqlClauseBuilder(builder, mapping, ClauseBindingFlags.Select,
                                 new DoSelectClauseBuilder(DoSelectSqlClauseBuilder), ignorProperties);

            return(builder);
        }
コード例 #4
0
 private static void FillSqlClauseBuilder(SelectSqlClauseBuilder builder, ORMappingItemCollection mapping,
                                          ClauseBindingFlags bindingFlags, DoSelectClauseBuilder builderDelegate, params string[] ignorProperties)
 {
     foreach (ORMappingItem item in mapping)
     {
         if (Array.Exists <string>(ignorProperties,
                                   delegate(string target)
         {
             return(string.Compare(target, item.PropertyName, true) == 0);
         }) == false)
         {
             if ((item.BindingFlags & bindingFlags) != ClauseBindingFlags.None)
             {
                 builderDelegate(builder, item);
             }
         }
     }
 }
コード例 #5
0
 private static void DoSelectSqlClauseBuilder(SelectSqlClauseBuilder builder, ORMappingItem item)
 {
     builder.AppendItem(item.DataFieldName);
 }