OracleBulkCopyColumnMapping کلاسی است که در فضای‌نام Oracle.DataAccess.Client وجود دارد و برای مدیریت مپینگ ستون‌ها در عملیات کپی داده با استفاده از کلاس OracleBulkCopy مورد استفاده قرار می‌گیرد.

وقتی از کلاس OracleBulkCopy برای کپی داده استفاده می‌کنید، ممکن است ستون‌های منبع داده و ستون‌های مقصد (ستون‌های جدول در پایگاه داده Oracle) با نام‌ها یا ترتیب متفاوتی مواجه شوند. در این صورت، برای مطابقت صحیح بین ستون‌های منبع و مقصد، می‌توانید از OracleBulkCopyColumnMapping استفاده کنید.

با استفاده از OracleBulkCopyColumnMapping، شما می‌توانید ستون‌های منبع و مقصد را به صورت دستی مپ کنید. برای هر مپینگ ستون، شما باید نام ستون منبع و نام ستون مقصد را مشخص کنید. به این ترتیب، در عملیات کپی داده، مقدار ستون منبع به ستون مقصد متناظر منتقل خواهد شد.

در زیر یک نمونه کد C# برای استفاده از OracleBulkCopyColumnMapping را می‌توانید مشاهده کنید:

```csharp
using Oracle.DataAccess.Client;

public class BulkCopyExample
{
public static void Main()
{
string connectionString = "Data Source=your-database;User Id=your-username;Password=your-password;";
string tableName = "your-table";
DataTable dataTable = GetDataTable(); // تابعی که DataTable مورد نیاز خود را بسازید

using (OracleConnection connection = new OracleConnection(connectionString))
{
connection.Open();

using (OracleBulkCopy bulkCopy = new OracleBulkCopy(connection))
{
bulkCopy.DestinationTableName = tableName;
bulkCopy.ColumnMappings.Add("SourceColumn1", "DestinationColumn1");
bulkCopy.ColumnMappings.Add("SourceColumn2", "DestinationColumn2");
// ...

bulkCopy.WriteToServer(dataTable);
}
}
}

private static DataTable GetDataTable()
{
// ساخت DataTable و افزودن رکوردها
DataTable dataTable = new DataTable();
dataTable.Columns.Add("SourceColumn1", typeof(int));
dataTable.Columns.Add("SourceColumn2", typeof(string));
dataTable.Rows.Add(1, "Value 1");
dataTable.Rows.Add(2, "Value 2");
// ...

return dataTable;
}
}
```

در این مثال، قبل از اجرای عملیات کپی داده با استفاده از OracleBulkCopy، مپینگ ستون‌ها با استفاده از OracleBulkCopyColumnMapping تعریف می‌شود. ستون "SourceColumn1" منبع داده به ستون "DestinationColumn1" جدول مقصد متناظر خواهد شد و ستون "SourceColumn2" منبع داده به ستون "DestinationColumn2" جدول مقصد متناظر خواهد شد. به طور مشابه، می‌توانید مپینگ ستون‌های دیگر را نیز تعریف کنید.

با استفاده از OracleBulkCopyColumnMapping، شما می‌توانید ستون‌های منبع و مقصد را به صورت دستی مپ کنید و مطابقت صحبین ستون‌های منبع و مقصد را در عملیات کپی داده برقرار کنید.