protected override DbDataReader ExecuteDbDataReader(CommandBehavior behavior) { var reader = new DataEntityDataReader <PropertyHandlerQueryTestClass>(new[] { new PropertyHandlerQueryTestClass { Id = 1, Name = "John Doe" } }); return(reader); }
protected override DbDataReader ExecuteDbDataReader(CommandBehavior behavior) { var reader = new DataEntityDataReader <ClassHandlerTestClass>(new[] { new ClassHandlerTestClass { Id = 1, Name = "James Doe" } }); return(reader); }
/// <summary> /// Bulk insert a list of data entity objects into the database in an asynchronous way. /// </summary> /// <typeparam name="TEntity">The type of the data entity object.</typeparam> /// <param name="connection">The connection object to be used.</param> /// <param name="entities">The list of the data entities to be bulk-inserted.</param> /// <param name="mappings">The list of the columns to be used for mappings. If this parameter is not set, then all columns will be used for mapping.</param> /// <param name="options">The bulk-copy options to be used.</param> /// <param name="bulkCopyTimeout">The timeout in seconds to be used.</param> /// <param name="batchSize">The size per batch to be used.</param> /// <param name="transaction">The transaction to be used.</param> /// <returns>The number of rows affected by the execution.</returns> public async Task <int> BulkInsertAsync <TEntity>(IDbConnection connection, IEnumerable <TEntity> entities, IEnumerable <BulkInsertMapItem> mappings = null, SqlBulkCopyOptions options = SqlBulkCopyOptions.Default, int?bulkCopyTimeout = null, int?batchSize = null, IDbTransaction transaction = null) where TEntity : class { // Validate the objects ValidateConnection(connection); ValidateTransaction(transaction); DbConnectionExtension.ValidateTransactionConnectionObject(connection, transaction); // Variables for the operation var result = 0; // Before Execution Time var beforeExecutionTime = DateTime.UtcNow; // Actual Execution using (var reader = new DataEntityDataReader <TEntity>(entities, connection)) { using (var sqlBulkCopy = new SqlBulkCopy((SqlConnection)connection, options, (SqlTransaction)transaction)) { // Set the destinationtable sqlBulkCopy.DestinationTableName = ClassMappedNameCache.Get <TEntity>(); // Set the timeout if (bulkCopyTimeout != null && bulkCopyTimeout.HasValue) { sqlBulkCopy.BulkCopyTimeout = bulkCopyTimeout.Value; } // Set the batch szie if (batchSize != null && batchSize.HasValue) { sqlBulkCopy.BatchSize = batchSize.Value; } // Add the mappings if (mappings == null) { foreach (var property in reader.Properties) { var columnName = property.GetUnquotedMappedName(); sqlBulkCopy.ColumnMappings.Add(columnName, columnName); } } else { foreach (var mapItem in mappings) { sqlBulkCopy.ColumnMappings.Add(mapItem.SourceColumn, mapItem.DestinationColumn); } } // Open the connection and do the operation await connection.EnsureOpenAsync(); await sqlBulkCopy.WriteToServerAsync(reader); // Hack the 'SqlBulkCopy' object var field = GetRowsCopiedField(); // Set the return value result = field != null ? (int)field.GetValue(sqlBulkCopy) : reader.RecordsAffected; } } // Result return(result); }
/// <summary> /// Bulk insert a list of data entity objects into the database in an asynchronous way. /// </summary> /// <typeparam name="TEntity">The type of the data entity object.</typeparam> /// <param name="connection">The connection object to be used.</param> /// <param name="entities">The list of the data entities to be bulk-inserted.</param> /// <param name="mappings">The list of the columns to be used for mappings. If this parameter is not set, then all columns will be used for mapping.</param> /// <param name="options">The bulk-copy options to be used.</param> /// <param name="bulkCopyTimeout">The timeout in seconds to be used.</param> /// <param name="batchSize">The size per batch to be used.</param> /// <param name="transaction">The transaction to be used.</param> /// <returns>The number of rows affected by the execution.</returns> public async Task <int> BulkInsertAsync <TEntity>(IDbConnection connection, IEnumerable <TEntity> entities, IEnumerable <BulkInsertMapItem> mappings = null, SqlBulkCopyOptions options = SqlBulkCopyOptions.Default, int?bulkCopyTimeout = null, int?batchSize = null, IDbTransaction transaction = null) where TEntity : class { // Validate the objects ValidateConnection(connection); ValidateTransaction(transaction); DbConnectionExtension.ValidateTransactionConnectionObject(connection, transaction); // Variables for the operation var result = 0; // Before Execution Time var beforeExecutionTime = DateTime.UtcNow; // Actual Execution using (var reader = new DataEntityDataReader <TEntity>(entities, connection)) { using (var sqlBulkCopy = new SqlBulkCopy((SqlConnection)connection, options, (SqlTransaction)transaction)) { var dbSetting = connection.GetDbSetting(); // Set the destinationtable sqlBulkCopy.DestinationTableName = ClassMappedNameCache.Get <TEntity>(dbSetting); // Set the timeout if (bulkCopyTimeout != null && bulkCopyTimeout.HasValue) { sqlBulkCopy.BulkCopyTimeout = bulkCopyTimeout.Value; } // Set the batch szie if (batchSize != null && batchSize.HasValue) { sqlBulkCopy.BatchSize = batchSize.Value; } // Add the mappings if (mappings == null) { // Get the actual DB fields var dbFields = await DbFieldCache.GetAsync(connection, ClassMappedNameCache.Get <TEntity>(dbSetting), transaction); var fields = reader.Properties.AsFields(); var filteredFields = new List <Tuple <string, string> >(); // To fix the casing problem of the bulk inserts foreach (var dbField in dbFields) { var field = fields.FirstOrDefault(f => string.Equals(f.UnquotedName, dbField.UnquotedName, StringComparison.OrdinalIgnoreCase)); if (field != null) { filteredFields.Add(new Tuple <string, string>(field.UnquotedName, dbField.UnquotedName)); } } // Iterate the filtered fields foreach (var field in filteredFields) { sqlBulkCopy.ColumnMappings.Add(field.Item1, field.Item2); } } else { // Iterate the provided mappings foreach (var mapItem in mappings) { sqlBulkCopy.ColumnMappings.Add(mapItem.SourceColumn, mapItem.DestinationColumn); } } // Open the connection and do the operation await connection.EnsureOpenAsync(); await sqlBulkCopy.WriteToServerAsync(reader); // Hack the 'SqlBulkCopy' object var copiedField = GetRowsCopiedField(); // Set the return value result = copiedField != null ? (int)copiedField.GetValue(sqlBulkCopy) : reader.RecordsAffected; } } // Result return(result); }