/// <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); }