| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461 |
- //
- // System.Data.OleDb.OleDbParameter
- //
- // Authors:
- // Rodrigo Moya ([email protected])
- // Tim Coleman ([email protected])
- //
- // Copyright (C) Rodrigo Moya, 2002
- // Copyright (C) Tim Coleman, 2002
- //
- //
- // Copyright (C) 2004 Novell, Inc (http://www.novell.com)
- //
- // Permission is hereby granted, free of charge, to any person obtaining
- // a copy of this software and associated documentation files (the
- // "Software"), to deal in the Software without restriction, including
- // without limitation the rights to use, copy, modify, merge, publish,
- // distribute, sublicense, and/or sell copies of the Software, and to
- // permit persons to whom the Software is furnished to do so, subject to
- // the following conditions:
- //
- // The above copyright notice and this permission notice shall be
- // included in all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
- // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
- // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
- // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- //
- using System;
- using System.Data;
- using System.Data.Common;
- using System.ComponentModel;
- namespace System.Data.OleDb
- {
- [TypeConverterAttribute (typeof (OleDbParameterConverter))]
- public sealed class OleDbParameter : MarshalByRefObject, IDbDataParameter, IDataParameter, ICloneable
- {
- #region Fields
- string name;
- object value;
- int size;
- bool isNullable;
- byte precision;
- byte scale;
- DataRowVersion sourceVersion;
- string sourceColumn;
- ParameterDirection direction;
- OleDbType oleDbType;
- DbType dbType;
- OleDbParameterCollection container = null;
- IntPtr gdaParameter;
- #endregion
- #region Constructors
-
- public OleDbParameter ()
- {
- name = String.Empty;
- value = null;
- size = 0;
- isNullable = true;
- precision = 0;
- scale = 0;
- sourceColumn = String.Empty;
- gdaParameter = IntPtr.Zero;
- }
- public OleDbParameter (string name, object value)
- : this ()
- {
- this.name = name;
- this.value = value;
- OleDbType = GetOleDbType (value);
- }
- public OleDbParameter (string name, OleDbType dataType)
- : this ()
- {
- this.name = name;
- OleDbType = dataType;
- }
- public OleDbParameter (string name, OleDbType dataType, int size)
- : this (name, dataType)
- {
- this.size = size;
- }
- public OleDbParameter (string name, OleDbType dataType, int size, string srcColumn)
- : this (name, dataType, size)
- {
- this.sourceColumn = srcColumn;
- }
-
- [EditorBrowsableAttribute (EditorBrowsableState.Advanced)]
- public OleDbParameter(string name, OleDbType dataType, int size, ParameterDirection direction, bool isNullable, byte precision, byte scale, string srcColumn, DataRowVersion srcVersion, object value)
- : this (name, dataType, size, srcColumn)
- {
- this.direction = direction;
- this.isNullable = isNullable;
- this.precision = precision;
- this.scale = scale;
- this.sourceVersion = srcVersion;
- this.value = value;
- }
- #endregion
- #region Properties
- [BrowsableAttribute (false)]
- #if !NET_2_0
- [DataSysDescriptionAttribute ("The parameter generic type.")]
- #endif
- [RefreshPropertiesAttribute (RefreshProperties.All)]
- [DesignerSerializationVisibilityAttribute (DesignerSerializationVisibility.Hidden)]
- [DataCategory ("DataCategory_Data")]
- public DbType DbType {
- get { return dbType; }
- set {
- dbType = value;
- oleDbType = DbTypeToOleDbType (value);
- }
- }
-
- #if !NET_2_0
- [DataSysDescriptionAttribute ("Input, output, or bidirectional parameter.")]
- #endif
- [DefaultValue (ParameterDirection.Input)]
- [DataCategory ("DataCategory_Data")]
- public ParameterDirection Direction {
- get { return direction; }
- set { direction = value; }
- }
-
- [BrowsableAttribute (false)]
- #if !NET_2_0
- [DataSysDescriptionAttribute ("a design-time property used for strongly typed code-generation.")]
- #endif
- [DesignOnlyAttribute (true)]
- [EditorBrowsableAttribute (EditorBrowsableState.Advanced)]
- [DefaultValue (false)]
- public bool IsNullable {
- get { return isNullable; }
- set { isNullable = value; }
- }
- [DefaultValue (OleDbType.VarWChar)]
- #if !NET_2_0
- [DataSysDescriptionAttribute ("The parameter native type.")]
- #endif
- [RefreshPropertiesAttribute (RefreshProperties.All)]
- [DataCategory ("DataCategory_Data")]
- public OleDbType OleDbType {
- get { return oleDbType; }
- set {
- oleDbType = value;
- dbType = OleDbTypeToDbType (value);
- }
- }
-
- [DefaultValue ("")]
- #if !NET_2_0
- [DataSysDescriptionAttribute ("Name of the parameter.")]
- #endif
- public string ParameterName {
- get { return name; }
- set { name = value; }
- }
- [DefaultValue (0)]
- #if !NET_2_0
- [DataSysDescriptionAttribute ("For decimal, numeric, varnumeric DBTypes.")]
- #endif
- [DataCategory ("DataCategory_Data")]
- public byte Precision {
- get { return precision; }
- set { precision = value; }
- }
-
- [DefaultValue (0)]
- #if !NET_2_0
- [DataSysDescriptionAttribute ("For decimal, numeric, varnumeric DBTypes.")]
- #endif
- [DataCategory ("DataCategory_Data")]
- public byte Scale {
- get { return scale; }
- set { scale = value; }
- }
-
- [DefaultValue (0)]
- #if !NET_2_0
- [DataSysDescriptionAttribute ("Size of variable length data types (string & arrays).")]
- #endif
- [DataCategory ("DataCategory_Data")]
- public int Size {
- get { return size; }
- set { size = value; }
- }
- [DefaultValue ("")]
- #if !NET_2_0
- [DataSysDescriptionAttribute ("When used by a DataAdapter.Update, the source column name that is used to find the DataSetColumn name in the ColumnMappings. This is to copy a value between the parameter and a datarow.")]
- #endif
- [DataCategory ("DataCategory_Data")]
- public string SourceColumn {
- get { return sourceColumn; }
- set { sourceColumn = value; }
- }
-
- [DefaultValue (DataRowVersion.Current)]
- #if !NET_2_0
- [DataSysDescriptionAttribute ("When used by a DataAdapter.Update (UpdateCommand only), the version of the DataRow value that is used to update the data source.")]
- #endif
- [DataCategory ("DataCategory_Data")]
- public DataRowVersion SourceVersion {
- get { return sourceVersion; }
- set { sourceVersion = value; }
- }
-
- [DefaultValue (null)]
- #if !NET_2_0
- [DataSysDescriptionAttribute ("Value of the parameter.")]
- #endif
- [TypeConverter (typeof (StringConverter))]
- [DataCategory ("DataCategory_Data")]
- public object Value {
- get { return value; }
- set { this.value = value; }
- }
- // Used to ensure that only one collection can contain this
- // parameter
- internal OleDbParameterCollection Container {
- get { return container; }
- set { container = value; }
- }
- #endregion // Properties
- #region Internal Properties
- internal IntPtr GdaParameter {
- get { return gdaParameter; }
- }
- #endregion // Internal Properties
- #region Methods
- [MonoTODO]
- object ICloneable.Clone ()
- {
- throw new NotImplementedException ();
- }
- public override string ToString ()
- {
- return ParameterName;
- }
- private OleDbType DbTypeToOleDbType (DbType dbType)
- {
- switch (dbType) {
- case DbType.AnsiString :
- return OleDbType.VarChar;
- case DbType.AnsiStringFixedLength :
- return OleDbType.Char;
- case DbType.Binary :
- return OleDbType.Binary;
- case DbType.Boolean :
- return OleDbType.Boolean;
- case DbType.Byte :
- return OleDbType.UnsignedTinyInt;
- case DbType.Currency :
- return OleDbType.Currency;
- case DbType.Date :
- return OleDbType.Date;
- case DbType.DateTime :
- throw new NotImplementedException ();
- case DbType.Decimal :
- return OleDbType.Decimal;
- case DbType.Double :
- return OleDbType.Double;
- case DbType.Guid :
- return OleDbType.Guid;
- case DbType.Int16 :
- return OleDbType.SmallInt;
- case DbType.Int32 :
- return OleDbType.Integer;
- case DbType.Int64 :
- return OleDbType.BigInt;
- case DbType.Object :
- return OleDbType.Variant;
- case DbType.SByte :
- return OleDbType.TinyInt;
- case DbType.Single :
- return OleDbType.Single;
- case DbType.String :
- return OleDbType.WChar;
- case DbType.StringFixedLength :
- return OleDbType.VarWChar;
- case DbType.Time :
- throw new NotImplementedException ();
- case DbType.UInt16 :
- return OleDbType.UnsignedSmallInt;
- case DbType.UInt32 :
- return OleDbType.UnsignedInt;
- case DbType.UInt64 :
- return OleDbType.UnsignedBigInt;
- case DbType.VarNumeric :
- return OleDbType.VarNumeric;
- }
- return OleDbType.Variant;
- }
- private DbType OleDbTypeToDbType (OleDbType oleDbType)
- {
- switch (oleDbType) {
- case OleDbType.BigInt :
- return DbType.Int64;
- case OleDbType.Binary :
- return DbType.Binary;
- case OleDbType.Boolean :
- return DbType.Boolean;
- case OleDbType.BSTR :
- return DbType.AnsiString;
- case OleDbType.Char :
- return DbType.AnsiStringFixedLength;
- case OleDbType.Currency :
- return DbType.Currency;
- case OleDbType.Date :
- return DbType.DateTime;
- case OleDbType.DBDate :
- return DbType.DateTime;
- case OleDbType.DBTime :
- throw new NotImplementedException ();
- case OleDbType.DBTimeStamp :
- return DbType.DateTime;
- case OleDbType.Decimal :
- return DbType.Decimal;
- case OleDbType.Double :
- return DbType.Double;
- case OleDbType.Empty :
- throw new NotImplementedException ();
- case OleDbType.Error :
- throw new NotImplementedException ();
- case OleDbType.Filetime :
- return DbType.DateTime;
- case OleDbType.Guid :
- return DbType.Guid;
- case OleDbType.IDispatch :
- return DbType.Object;
- case OleDbType.Integer :
- return DbType.Int32;
- case OleDbType.IUnknown :
- return DbType.Object;
- case OleDbType.LongVarBinary :
- return DbType.Binary;
- case OleDbType.LongVarChar :
- return DbType.AnsiString;
- case OleDbType.LongVarWChar :
- return DbType.String;
- case OleDbType.Numeric :
- return DbType.Decimal;
- case OleDbType.PropVariant :
- return DbType.Object;
- case OleDbType.Single :
- return DbType.Single;
- case OleDbType.SmallInt :
- return DbType.Int16;
- case OleDbType.TinyInt :
- return DbType.SByte;
- case OleDbType.UnsignedBigInt :
- return DbType.UInt64;
- case OleDbType.UnsignedInt :
- return DbType.UInt32;
- case OleDbType.UnsignedSmallInt :
- return DbType.UInt16;
- case OleDbType.UnsignedTinyInt :
- return DbType.Byte;
- case OleDbType.VarBinary :
- return DbType.Binary;
- case OleDbType.VarChar :
- return DbType.AnsiString;
- case OleDbType.Variant :
- return DbType.Object;
- case OleDbType.VarNumeric :
- return DbType.VarNumeric;
- case OleDbType.VarWChar :
- return DbType.StringFixedLength;
- case OleDbType.WChar :
- return DbType.String;
- }
- return DbType.Object;
- }
- private OleDbType GetOleDbType (object value)
- {
- if (value is Guid) return OleDbType.Guid;
- if (value is TimeSpan) return OleDbType.DBTime;
- switch (Type.GetTypeCode (value.GetType ())) {
- case TypeCode.Boolean :
- return OleDbType.Boolean;
- case TypeCode.Byte :
- if (value.GetType().IsArray)
- return OleDbType.Binary;
- else
- return OleDbType.UnsignedTinyInt;
- case TypeCode.Char :
- return OleDbType.Char;
- case TypeCode.DateTime :
- return OleDbType.Date;
- case TypeCode.DBNull :
- return OleDbType.Empty;
- case TypeCode.Decimal :
- return OleDbType.Decimal;
- case TypeCode.Double :
- return OleDbType.Double;
- case TypeCode.Empty :
- return OleDbType.Empty;
- case TypeCode.Int16 :
- return OleDbType.SmallInt;
- case TypeCode.Int32 :
- return OleDbType.Integer;
- case TypeCode.Int64 :
- return OleDbType.BigInt;
- case TypeCode.SByte :
- return OleDbType.TinyInt;
- case TypeCode.String :
- return OleDbType.VarChar;
- case TypeCode.Single :
- return OleDbType.Single;
- case TypeCode.UInt64 :
- return OleDbType.UnsignedBigInt;
- case TypeCode.UInt32 :
- return OleDbType.UnsignedInt;
- case TypeCode.UInt16 :
- return OleDbType.UnsignedSmallInt;
- case TypeCode.Object :
- return OleDbType.Variant;
- }
- return OleDbType.IUnknown;
- }
- #endregion
- }
- }
|