ETLBox.Xml
3.6.0
See the version list below for details.
dotnet add package ETLBox.Xml --version 3.6.0
NuGet\Install-Package ETLBox.Xml -Version 3.6.0
<PackageReference Include="ETLBox.Xml" Version="3.6.0" />
paket add ETLBox.Xml --version 3.6.0
#r "nuget: ETLBox.Xml, 3.6.0"
// Install ETLBox.Xml as a Cake Addin #addin nuget:?package=ETLBox.Xml&version=3.6.0 // Install ETLBox.Xml as a Cake Tool #tool nuget:?package=ETLBox.Xml&version=3.6.0
ETLBox - Lightweight ETL and Data Integration for .NET
Get Started | Overview | Code Examples | Licensing | Free Trial
What is ETLBox?
ETLBox is a lightweight ETL (Extract, Transform, Load) library and data integration toolbox for .NET. It helps you create and manage data integration pipelines to extract data from different sources, transform it into the format you need, and load it into databases, APIs, or files. Whether you're migrating data, synchronizing systems, or automating workflows, ETLBox provides the components to handle these tasks efficiently.
ETLBox is a flexible alternative to traditional ETL tools like SQL Server Integration Services (SSIS) or Azure Data Factory. Unlike those tools, ETLBox does not rely on a graphical user interface, making it ideal for developers who prefer programmatic control. It supports parallel execution and real-time processing, making it a solid choice for building scalable data solutions.
Feature Overview
- Scalable Pipelines - Handle large data volumes with bulk operations and parallel processing.
- Flexible Connectors - Connect to SQL, NoSQL, APIs, and flat files like CSV, Excel, and JSON.
- Streaming Support - Process real-time data streams and keep workflows updated.
- Transformations - Harmonize, filter, aggregate, and clean data with built-in tools.
- Cloud-Ready - Deploy on Azure, AWS, Docker, and Kubernetes.
- Custom Extensions - Build and integrate your own transformations and connectors.
Why Choose ETLBox?
ETLBox lets you build data pipelines that process structured and unstructured data from various sources, including databases, APIs, and flat files. It automates tasks like data transformation, validation, and cleaning, and supports bulk inserts, updates, and deletes. With its ability to handle streaming data and parallel workflows, ETLBox delivers performance and flexibility for modern data integration tasks. Developers can rely on built-in connectors or extend the library to fit custom requirements.
Using ETLBox
Example 1: Bulk Insert into SQL Database
string connString =
@"Source=.;Trusted_Connection=true;Initial Catalog=ETLBox;"
var destCon = new SqlConnectionManager(connString);
//Create the dataflow components
var source = new CsvSource(sourceCon, "SourceData.csv");
var dest = new DbDestination(destCon, "DestinationTable");
//Default mapping: Csv header and column name match (case-sensitive)
//Override mapping like this:
dest.ColumnMapping = new[] {
new DbColumnMap() {
DbColumnName = "Id", PropertyName = "OrderNumber"
}
};
//Link the source and destination, run the dataflow
source.LinkTo(dest);
await Network.ExecuteAsnyc(source);
Example 2: Migrate Between Databases
string mySqlConnString =
@"Server=localhost;Database=ETLBox;Uid=user;Pwd=password;";
string postgresConnString =
@"Server=.;Initial Catalog=ETLBox;Trusted_Connection=true;";
var sourceCon = new MySqlConnectionManager(mySqlConnString);
var destCon = new PostgresConnectionManager(postgresConnString);
//Create the dataflow components
var source = new DbSource(sourceCon, "SourceTableName");
var dest = new DbDestination(destCon, "DestTableName");
//Link the source and destination, run the dataflow
source.LinkTo(dest);
await Network.ExecuteAsync(source);
Example 3: Merge Data Between Tables
public class MyMergeRow : MergeableRow
{
[IdColumn]
public long Key { get; set; }
[CompareColumn]
[UpdateColumn]
public string Value { get; set; }
[DeleteColumn(true)]
public bool DeleteThisRow { get; set; }
}
//Create the dataflow components
DbSource<MyMergeRow> source = new (connection, "SourceTable");
DbMerge<MyMergeRow> mergeDest = new (connection, "DestinationTable");
merge.MergeMode = MergeMode.Full;
merge.CacheMode = CacheMode.Partial;
//Link the source and destination, run the dataflow
source.LinkTo(merge);
Network.Execute(source);
Licensing & Support
For our full list of code examples, tutorials, licensing information, and documentation visit: www.etlbox.net
For more support and inquiries, please email us at: support@etlbox.net
Documentation Links
Ready to build your ETL pipelines? Start now at www.etlbox.net.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- ETLBox (>= 3.6.0)
- Newtonsoft.Json (>= 13.0.3)
-
net8.0
- ETLBox (>= 3.6.0)
- Newtonsoft.Json (>= 13.0.3)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
3.6.1 | 1,752 | 1/6/2025 |
3.6.0 | 84 | 1/6/2025 |
3.5.2 | 2,919 | 12/20/2024 |
3.5.1 | 101 | 11/15/2024 |
3.5.0 | 106 | 10/14/2024 |
3.4.4 | 115 | 9/30/2024 |
3.4.3 | 104 | 9/12/2024 |
3.4.2 | 126 | 9/3/2024 |
3.4.1 | 104 | 7/15/2024 |
3.4.0 | 119 | 5/29/2024 |
3.3.0 | 168 | 3/14/2024 |
3.2.0 | 176 | 1/11/2024 |
3.1.0 | 233 | 11/24/2023 |
3.0.2 | 151 | 10/6/2023 |
3.0.1 | 146 | 9/27/2023 |
3.0.0 | 1,369 | 7/11/2023 |
2.7.1 | 177 | 6/5/2023 |
2.7.0 | 219 | 4/4/2023 |
2.6.8 | 312 | 2/9/2023 |
2.6.7 | 393 | 1/9/2023 |
2.6.6 | 440 | 10/28/2022 |
2.6.5 | 430 | 10/19/2022 |
2.6.4 | 416 | 10/10/2022 |
2.6.3 | 472 | 9/26/2022 |
2.6.2 | 467 | 7/8/2022 |
2.6.1 | 458 | 5/19/2022 |
2.6.0 | 485 | 3/22/2022 |
2.5.2 | 334 | 12/30/2021 |
2.5.1 | 388 | 10/8/2021 |
2.5.0 | 357 | 9/27/2021 |
2.4.4 | 429 | 8/4/2021 |
2.4.3 | 387 | 7/16/2021 |
2.4.2 | 372 | 7/2/2021 |
2.4.1 | 711 | 5/17/2021 |
2.4.0 | 369 | 4/13/2021 |
1.3.1 | 413 | 2/16/2021 |
1.3.0 | 438 | 1/11/2021 |
1.2.5 | 453 | 12/21/2020 |
1.2.4 | 427 | 12/15/2020 |
1.2.3 | 482 | 12/4/2020 |
1.2.2 | 439 | 11/23/2020 |
1.2.1 | 573 | 11/20/2020 |
1.2.0 | 471 | 11/17/2020 |
1.1.1 | 501 | 9/24/2020 |
1.1.0 | 489 | 9/3/2020 |
1.0.2 | 529 | 7/1/2020 |
1.0.1 | 549 | 6/19/2020 |
1.0.0 | 497 | 6/10/2020 |
We are constantly improving ETLBox—adding new features, fixing bugs, and enhancing performance to make data integration even easier.
For the latest updates and detailed release notes, visit: https://www.etlbox.net/release-notes/