459 lines
11 KiB
C#
459 lines
11 KiB
C#
|
//
|
||
|
// System.Data.OleDb.OleDbParameter
|
||
|
//
|
||
|
// Authors:
|
||
|
// Rodrigo Moya (rodrigo@ximian.com)
|
||
|
// Tim Coleman (tim@timcoleman.com)
|
||
|
//
|
||
|
// 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 ("System.Data.OleDb.OleDbParameter+OleDbParameterConverter, " + Consts.AssemblySystem_Data)]
|
||
|
public sealed class OleDbParameter : DbParameter, IDbDataParameter, ICloneable
|
||
|
{
|
||
|
#region Fields
|
||
|
|
||
|
string name;
|
||
|
object value;
|
||
|
int size;
|
||
|
bool isNullable;
|
||
|
byte precision;
|
||
|
byte scale;
|
||
|
DataRowVersion sourceVersion;
|
||
|
string sourceColumn;
|
||
|
bool sourceColumnNullMapping;
|
||
|
ParameterDirection direction;
|
||
|
OleDbType oleDbType;
|
||
|
DbType dbType;
|
||
|
OleDbParameterCollection container;
|
||
|
IntPtr gdaParameter;
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Constructors
|
||
|
|
||
|
public OleDbParameter ()
|
||
|
{
|
||
|
name = string.Empty;
|
||
|
isNullable = true;
|
||
|
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 parameterName, OleDbType dbType, int size, ParameterDirection direction, bool isNullable, byte precision, byte scale, string srcColumn, DataRowVersion srcVersion, object value)
|
||
|
: this (parameterName, dbType, size, srcColumn)
|
||
|
{
|
||
|
this.direction = direction;
|
||
|
this.isNullable = isNullable;
|
||
|
this.precision = precision;
|
||
|
this.scale = scale;
|
||
|
this.sourceVersion = srcVersion;
|
||
|
this.value = value;
|
||
|
}
|
||
|
|
||
|
[EditorBrowsable (EditorBrowsableState.Advanced)]
|
||
|
public OleDbParameter (string parameterName, OleDbType dbType, int size, ParameterDirection direction, byte precision, byte scale, string sourceColumn, DataRowVersion sourceVersion, bool sourceColumnNullMapping, object value)
|
||
|
: this (parameterName, dbType, size, sourceColumn)
|
||
|
{
|
||
|
this.direction = direction;
|
||
|
this.precision = precision;
|
||
|
this.scale = scale;
|
||
|
this.sourceVersion = sourceVersion;
|
||
|
this.sourceColumnNullMapping = sourceColumnNullMapping;
|
||
|
this.value = value;
|
||
|
}
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Properties
|
||
|
|
||
|
[DataCategory ("DataCategory_Data")]
|
||
|
public
|
||
|
override
|
||
|
DbType DbType {
|
||
|
get { return dbType; }
|
||
|
set {
|
||
|
dbType = value;
|
||
|
oleDbType = DbTypeToOleDbType (value);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[RefreshProperties (RefreshProperties.All)]
|
||
|
[DataCategory ("DataCategory_Data")]
|
||
|
public
|
||
|
override
|
||
|
ParameterDirection Direction {
|
||
|
get { return direction; }
|
||
|
set { direction = value; }
|
||
|
}
|
||
|
|
||
|
public
|
||
|
override
|
||
|
bool IsNullable {
|
||
|
get { return isNullable; }
|
||
|
set { isNullable = value; }
|
||
|
}
|
||
|
|
||
|
[DbProviderSpecificTypeProperty (true)]
|
||
|
[RefreshPropertiesAttribute (RefreshProperties.All)]
|
||
|
[DataCategory ("DataCategory_Data")]
|
||
|
public OleDbType OleDbType {
|
||
|
get { return oleDbType; }
|
||
|
set {
|
||
|
oleDbType = value;
|
||
|
dbType = OleDbTypeToDbType (value);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public
|
||
|
override
|
||
|
string ParameterName {
|
||
|
get { return name; }
|
||
|
set { name = value; }
|
||
|
}
|
||
|
|
||
|
[DefaultValue (0)]
|
||
|
[DataCategory ("DataCategory_Data")]
|
||
|
public byte Precision {
|
||
|
get { return precision; }
|
||
|
set { precision = value; }
|
||
|
}
|
||
|
|
||
|
[DefaultValue (0)]
|
||
|
[DataCategory ("DataCategory_Data")]
|
||
|
public byte Scale {
|
||
|
get { return scale; }
|
||
|
set { scale = value; }
|
||
|
}
|
||
|
|
||
|
[DataCategory ("DataCategory_Data")]
|
||
|
public
|
||
|
override
|
||
|
int Size {
|
||
|
get { return size; }
|
||
|
set { size = value; }
|
||
|
}
|
||
|
|
||
|
[DataCategory ("DataCategory_Data")]
|
||
|
public
|
||
|
override
|
||
|
string SourceColumn {
|
||
|
get { return sourceColumn; }
|
||
|
set { sourceColumn = value; }
|
||
|
}
|
||
|
|
||
|
public override bool SourceColumnNullMapping {
|
||
|
get {
|
||
|
return sourceColumnNullMapping;
|
||
|
} set {
|
||
|
sourceColumnNullMapping = value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[DataCategory ("DataCategory_Data")]
|
||
|
public
|
||
|
override
|
||
|
DataRowVersion SourceVersion {
|
||
|
get { return sourceVersion; }
|
||
|
set { sourceVersion = value; }
|
||
|
}
|
||
|
|
||
|
[RefreshPropertiesAttribute (RefreshProperties.All)]
|
||
|
[TypeConverter (typeof (StringConverter))]
|
||
|
[DataCategory ("DataCategory_Data")]
|
||
|
public
|
||
|
override
|
||
|
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 void ResetDbType ()
|
||
|
{
|
||
|
ResetOleDbType ();
|
||
|
}
|
||
|
|
||
|
public void ResetOleDbType ()
|
||
|
{
|
||
|
oleDbType = GetOleDbType (Value);
|
||
|
dbType = OleDbTypeToDbType (oleDbType);
|
||
|
}
|
||
|
|
||
|
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
|
||
|
}
|
||
|
}
|