2
0

DataColumnMapping.cs 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. //
  2. // System.Data.Common.DataColumnMapping
  3. //
  4. // Authors:
  5. // Rodrigo Moya ([email protected])
  6. // Tim Coleman ([email protected])
  7. //
  8. // (C) Ximian, Inc
  9. // Copyright (C) Tim Coleman, 2002
  10. //
  11. using System.ComponentModel;
  12. using System.Data;
  13. namespace System.Data.Common {
  14. public sealed class DataColumnMapping : MarshalByRefObject, IColumnMapping, ICloneable
  15. {
  16. #region Fields
  17. string sourceColumn;
  18. string dataSetColumn;
  19. #endregion // Fields
  20. #region Constructors
  21. public DataColumnMapping ()
  22. {
  23. sourceColumn = String.Empty;
  24. dataSetColumn = String.Empty;
  25. }
  26. public DataColumnMapping (string sourceColumn, string dataSetColumn)
  27. {
  28. this.sourceColumn = sourceColumn;
  29. this.dataSetColumn = dataSetColumn;
  30. }
  31. #endregion // Constructors
  32. #region Properties
  33. [DataSysDescription ("DataColumn.ColumnName")]
  34. [DefaultValue ("")]
  35. public string DataSetColumn {
  36. get { return dataSetColumn; }
  37. set { dataSetColumn = value; }
  38. }
  39. [DataSysDescription ("Source column name - case sensitive.")]
  40. [DefaultValue ("")]
  41. public string SourceColumn {
  42. get { return sourceColumn; }
  43. set { sourceColumn = value; }
  44. }
  45. #endregion // Properties
  46. #region Methods
  47. [EditorBrowsable (EditorBrowsableState.Advanced)]
  48. public DataColumn GetDataColumnBySchemaAction (DataTable dataTable, Type dataType, MissingSchemaAction schemaAction)
  49. {
  50. if (dataTable.Columns.Contains (dataSetColumn))
  51. return dataTable.Columns [dataSetColumn];
  52. if (schemaAction == MissingSchemaAction.Ignore)
  53. return null;
  54. if (schemaAction == MissingSchemaAction.Error)
  55. throw new InvalidOperationException (String.Format ("Missing the DataColumn '{0}' in the DataTable '{1}' for the SourceColumn '{2}'", DataSetColumn, dataTable.TableName, SourceColumn));
  56. return new DataColumn (dataSetColumn, dataType);
  57. }
  58. object ICloneable.Clone ()
  59. {
  60. return new DataColumnMapping (SourceColumn, DataSetColumn);
  61. }
  62. public override string ToString ()
  63. {
  64. return SourceColumn;
  65. }
  66. #endregion // Methods
  67. }
  68. }