Esempio n. 1
0
        /// <summary>
        /// Insert a single entity of type T to the database
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="hopper">   </param>
        /// <param name="instance">Instance to insert to database</param>
        /// <exception cref="ArgumentNullException">thrown when instance is null</exception>
        public static void InsertSingle <T>(this IHop hopper, T instance) where T : new()
        {
            if (instance == null)
            {
                throw new ArgumentNullException("instance", "Please provide a non null value to parameter instace ");
            }

            hopper.Insert(new[] { instance });
        }
Esempio n. 2
0
        /// <summary>
        /// Inserts a collection of entities to the database
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="hopper"></param>
        /// <param name="instances">Collection to insert</param>
        /// <exception cref="ArgumentNullException"></exception>
        public static void Insert <T>(this IHop hopper, ICollection <T> instances) where T : new()
        {
            if (instances == null)
            {
                throw new ArgumentNullException("instances", "Please provide a non null value to parameter instances");
            }

            if (!instances.Any())
            {
                return;
            }

            SchemaVerifierService.AddTypeToCache <T>(hopper.Connection);

            var propertyInfos = TypeCache.Get <T>().PropertiesWithoutId;
            var objects       =
                instances
                .Select(objToInsert =>
                        propertyInfos
                        .Select(prop => prop.GetValue(objToInsert, null).ToSqlString())
                        .Aggregate((field1, field2) => field1 + ", " + field2)
                        );

            var tableName  = HopBase.GetTypeToTableNameService(typeof(T));
            var columnList =
                propertyInfos
                .Select(x => x.Name)
                .Aggregate((field1, field2) => field1 + ", " + field2);

            var intoClause   = string.Format("{0} ({1})", tableName, columnList);
            var valuesClause =
                objects
                .Select(x => "(" + x + ")")
                .Aggregate((obj1, obj2) => obj1 + ", " + obj2);

            var lastId = hopper.Insert <T>(intoClause, valuesClause);

            foreach (T source in instances.Reverse())
            {
                HopBase.GetIdExtractorService().SetId(source, lastId--);
            }
        }