Esempio n. 1
0
        /// <summary>
        /// Inserts the given objects into the given table. The first object "id" is ignored due to the auto increment,
        /// <para/>
        /// SQL query Example: <para/>
        /// INSERT INTO table3 (Name, Date, value) VALUES ('John Doe', '2018-12-06 12:01:16.767', 22.5);
        /// </summary>
        /// <param name="tableName">The name of the table to insert rows to.</param>
        /// <param name="rows">A list of rows with all column objects to insert.</param>
        /// <param name="tables">All saved tables.</param>
        public override void InsertIntoTable(string tableName, Dictionary <string, Table> tables, List <List <object> > rows)
        {
            List <string> queryList = new List <string>();

            foreach (List <object> row in rows)
            {
                SQLQueryBuilder sqb           = new SQLQueryBuilder();
                List <string>   firstBracket  = new List <string>();
                List <string>   secondBracket = new List <string>();
                int             listIter      = 0;
                foreach (KeyValuePair <string, Type> column in tables[tableName].Columns)
                {
                    if (listIter.Equals(0))
                    {
                        listIter++;
                        continue;
                    }

                    if (!row[listIter].GetType().Equals(column.Value))
                    {
                        throw new TypeLoadException("Type of the data doesn't match the columns type!");
                    }

                    firstBracket.Add(sqb.AddValue(column.Key).Flush());

                    if (column.Value == typeof(int))
                    {
                        sqb.AddValue(row[listIter].ToString());
                    }
                    else if (column.Value == typeof(string))
                    {
                        sqb.Apostrophe(sqb.AddValue(row[listIter].ToString()).Flush());
                    }
                    else if (column.Value == typeof(double))
                    {
                        sqb.AddValue(row[listIter].ToString().Replace(',', '.'));
                    }
                    else if (column.Value == typeof(float))
                    {
                        sqb.AddValue(row[listIter].ToString().Replace(',', '.'));
                    }
                    else if (column.Value == typeof(DateTime))
                    {
                        DateTime convertTime = (DateTime)row[listIter];
                        sqb.Apostrophe(sqb.AddValue(convertTime.ToString(_stringFormat)).Flush());
                    }
                    else
                    {
                        throw new NotSupportedException(column.Value.Name + " Datatype not supported");
                    }

                    secondBracket.Add(sqb.Flush());
                    listIter++;
                }
                string columnNames  = sqb.Brackets_Multiple(firstBracket, false).Flush();
                string columnValues = sqb.Brackets_Multiple(secondBracket, false).Flush();
                sqb.InsertInto().AddValue(tableName).AddValue(columnNames).Values().AddValue(columnValues);
                queryList.Add(sqb.ToString());
            }
            CommitBatchQuery(queryList);
        }