| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588 |
- //
- // OracleParameter.cs
- //
- // Part of the Mono class libraries at
- // mcs/class/System.Data.OracleClient/System.Data.OracleClient
- //
- // Assembly: System.Data.OracleClient.dll
- // Namespace: System.Data.OracleClient
- //
- // Authors:
- // Tim Coleman <[email protected]>
- // Daniel Moragn <[email protected]>
- //
- // Copyright (C) Tim Coleman , 2003
- // Copyright (C) Daniel Morgan, 2005
- //
- // Licensed under the MIT/X11 License.
- //
- using System;
- using System.Collections;
- using System.ComponentModel;
- using System.Data;
- using System.Data.OracleClient.Oci;
- using System.Globalization;
- using System.Runtime.InteropServices;
- using System.Text;
- namespace System.Data.OracleClient {
- [TypeConverter (typeof(OracleParameter.OracleParameterConverter))]
- public sealed class OracleParameter : MarshalByRefObject, IDbDataParameter, IDataParameter, ICloneable
- {
- #region Fields
- string name;
- OracleType oracleType = OracleType.VarChar;
- OciDataType ociType;
- int size;
- ParameterDirection direction = ParameterDirection.Input;
- bool isNullable;
- byte precision;
- byte scale;
- string srcColumn;
- DataRowVersion srcVersion;
- DbType dbType = DbType.AnsiString;
- int offset = 0;
- bool sizeSet = false;
- object value = null;
- OciLobLocator lobLocator = null; // only if Blob or Clob
- OracleParameterCollection container = null;
- OciBindHandle bindHandle;
- #endregion // Fields
- #region Constructors
- public OracleParameter ()
- : this (String.Empty, OracleType.VarChar, 0, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, null)
- {
- }
- public OracleParameter (string name, object value)
- {
- this.name = name;
- this.value = value;
- SourceVersion = DataRowVersion.Current;
- InferOracleType (value);
- }
- public OracleParameter (string name, OracleType dataType)
- : this (name, dataType, 0, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, null)
- {
- }
- public OracleParameter (string name, OracleType dataType, int size)
- : this (name, dataType, size, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, null)
- {
- }
- public OracleParameter (string name, OracleType dataType, int size, string srcColumn)
- : this (name, dataType, size, ParameterDirection.Input, false, 0, 0, srcColumn, DataRowVersion.Current, null)
- {
- }
- public OracleParameter (string name, OracleType dataType, int size, ParameterDirection direction, bool isNullable, byte precision, byte scale, string srcColumn, DataRowVersion srcVersion, object value)
- {
- this.name = name;
- this.size = size;
- this.value = value;
- OracleType = dataType;
- Direction = direction;
- SourceColumn = srcColumn;
- SourceVersion = srcVersion;
- }
- #endregion // Constructors
- #region Properties
- internal OracleParameterCollection Container {
- get { return container; }
- set { container = value; }
- }
- [Browsable (false)]
- [RefreshProperties (RefreshProperties.All)]
- [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)]
- public DbType DbType {
- get { return dbType; }
- set { SetDbType (value); }
- }
- [DefaultValue (ParameterDirection.Input)]
- [RefreshProperties (RefreshProperties.All)]
- public ParameterDirection Direction {
- get { return direction; }
- set { direction = value; }
- }
- [Browsable (false)]
- [DesignOnly (true)]
- [DefaultValue (false)]
- [EditorBrowsable (EditorBrowsableState.Never)]
- public bool IsNullable {
- get { return isNullable; }
- set { isNullable = value; }
- }
- [DefaultValue (0)]
- [Browsable (false)]
- public int Offset {
- get { return offset; }
- set { offset = value; }
- }
- [DefaultValue (OracleType.VarChar)]
- [RefreshProperties (RefreshProperties.All)]
- public OracleType OracleType {
- get { return oracleType; }
- set { SetOracleType (value); }
- }
-
- [DefaultValue ("")]
- public string ParameterName {
- get { return name; }
- set { name = value; }
- }
- [DefaultValue (0)]
- public byte Precision {
- get { return precision; }
- set { /* NO EFFECT*/ }
- }
- [DefaultValue (0)]
- public byte Scale {
- get { return scale; }
- set { /* NO EFFECT*/ }
- }
- [DefaultValue (0)]
- public int Size {
- get { return size; }
- set {
- sizeSet = true;
- size = value;
- }
- }
- [DefaultValue ("")]
- public string SourceColumn {
- get { return srcColumn; }
- set { srcColumn = value; }
- }
- [DefaultValue (DataRowVersion.Current)]
- public DataRowVersion SourceVersion {
- get { return srcVersion; }
- set { srcVersion = value; }
- }
- [DefaultValue (null)]
- [RefreshProperties (RefreshProperties.All)]
- [TypeConverter (typeof(StringConverter))]
- public object Value {
- get { return this.value; }
- set { this.value = value; }
- }
- #endregion // Properties
- #region Methods
- private void AssertSizeIsSet ()
- {
- if (!sizeSet)
- throw new Exception ("Size must be set.");
- }
- internal void Bind (OciStatementHandle statement, OracleConnection connection)
- {
- if (bindHandle == null)
- bindHandle = new OciBindHandle ((OciHandle) statement);
- IntPtr tmpHandle = bindHandle.Handle;
- if (Direction != ParameterDirection.Input)
- AssertSizeIsSet ();
- if (!sizeSet)
- size = InferSize ();
- byte[] bytes = null;
- int status = 0;
- int indicator = 0;
- OciDataType bindType = ociType;
- IntPtr bindValue = IntPtr.Zero;
- int bindSize = size;
- int rsize = 0;
- if (value == DBNull.Value) {
- indicator = 0;
- bindType = OciDataType.VarChar2;
- bindSize = 0;
- }
- else {
- // TODO: do other data types and oracle data types
- // should I be using IConvertible to convert?
- if (oracleType == OracleType.DateTime) {
- string oraDateFormat = connection.GetSessionDateFormat ();
- string sysDateFormat = OracleDateTime.ConvertOracleDateFormatToSystemDateTime (oraDateFormat);
- string sDate = "";
- DateTime dt = DateTime.MinValue;
- if (value is String) {
- sDate = (string) value;
- dt = DateTime.Parse (sDate);
- }
- else if (value is DateTime)
- dt = (DateTime) value;
- else if (value is OracleString) {
- sDate = (string) value;
- dt = DateTime.Parse (sDate);
- }
- else if (value is OracleDateTime) {
- OracleDateTime odt = (OracleDateTime) value;
- dt = (DateTime) odt.Value;
- }
- else
- throw new NotImplementedException (); // ?
- sDate = dt.ToString (sysDateFormat);
- rsize = 0;
-
- // Get size of buffer
- OciCalls.OCIUnicodeToCharSet (statement.Parent, null, sDate, out rsize);
-
- // Fill buffer
- bytes = new byte[rsize];
- OciCalls.OCIUnicodeToCharSet (statement.Parent, bytes, sDate, out rsize);
-
- bindType = OciDataType.VarChar2;
- //bindValue = Marshal.StringToHGlobalAnsi (sDate);
- bindSize = sDate.Length;
- }
- else if (oracleType == OracleType.Blob) {
- bytes = (byte[]) value;
- bindType = OciDataType.LongRaw;
- bindSize = bytes.Length;
- }
- else if (oracleType == OracleType.Clob) {
- string v = (string) value;
- rsize = 0;
-
- // Get size of buffer
- OciCalls.OCIUnicodeToCharSet (statement.Parent, null, v, out rsize);
-
- // Fill buffer
- bytes = new byte[rsize];
- OciCalls.OCIUnicodeToCharSet (statement.Parent, bytes, v, out rsize);
- bindType = OciDataType.Long;
- bindSize = bytes.Length;
- }
- else if (oracleType == OracleType.Raw) {
- byte[] val = value as byte[];
- bindValue = Marshal.AllocHGlobal (val.Length);
- Marshal.Copy (val, 0, bindValue, val.Length);
- bindSize = val.Length;
- }
- else {
- string svalue = value.ToString ();
- rsize = 0;
-
- // Get size of buffer
- OciCalls.OCIUnicodeToCharSet (statement.Parent, null, svalue, out rsize);
-
- // Fill buffer
- bytes = new byte[rsize];
- OciCalls.OCIUnicodeToCharSet (statement.Parent, bytes, svalue, out rsize);
- //bindValue = Marshal.StringToHGlobalAnsi (value.ToString ());
- bindType = OciDataType.VarChar2;
- bindSize = value.ToString ().Length;
- }
- }
- if (bytes != null) {
- status = OciCalls.OCIBindByNameBytes (statement,
- out tmpHandle,
- connection.ErrorHandle,
- ParameterName,
- ParameterName.Length,
- bytes,
- bindSize,
- bindType,
- indicator,
- IntPtr.Zero,
- IntPtr.Zero,
- 0,
- IntPtr.Zero,
- 0);
- }
- else {
- status = OciCalls.OCIBindByName (statement,
- out tmpHandle,
- connection.ErrorHandle,
- ParameterName,
- ParameterName.Length,
- bindValue,
- bindSize,
- bindType,
- indicator,
- IntPtr.Zero,
- IntPtr.Zero,
- 0,
- IntPtr.Zero,
- 0);
- }
- if (status != 0) {
- OciErrorInfo info = connection.ErrorHandle.HandleError ();
- throw new OracleException (info.ErrorCode, info.ErrorMessage);
- }
- bindHandle.SetHandle (tmpHandle);
- }
- [MonoTODO]
- object ICloneable.Clone ()
- {
- throw new NotImplementedException ();
- }
- private void InferOracleType (object value)
- {
- Type type = value.GetType ();
- string exception = String.Format ("The parameter data type of {0} is invalid.", type.Name);
- switch (type.FullName) {
- case "System.Int64":
- SetOracleType (OracleType.Number);
- break;
- case "System.Boolean":
- case "System.Byte":
- SetOracleType (OracleType.Byte);
- break;
- case "System.String":
- SetOracleType (OracleType.VarChar);
- break;
- case "System.DateTime":
- SetOracleType (OracleType.DateTime);
- break;
- case "System.Decimal":
- SetOracleType (OracleType.Number);
- //scale = ((decimal) value).Scale;
- break;
- case "System.Double":
- SetOracleType (OracleType.Double);
- break;
- case "System.Byte[]":
- case "System.Guid":
- SetOracleType (OracleType.Raw);
- break;
- case "System.Int32":
- SetOracleType (OracleType.Int32);
- break;
- case "System.Single":
- SetOracleType (OracleType.Float);
- break;
- case "System.Int16":
- SetOracleType (OracleType.Int16);
- break;
- default:
- throw new ArgumentException (exception);
- }
- }
- [MonoTODO ("different size depending on type.")]
- private int InferSize ()
- {
- return value.ToString ().Length;
- }
- private void SetDbType (DbType type)
- {
- string exception = String.Format ("No mapping exists from DbType {0} to a known OracleType.", type);
- switch (type) {
- case DbType.AnsiString:
- oracleType = OracleType.VarChar;
- ociType = OciDataType.VarChar;
- break;
- case DbType.AnsiStringFixedLength:
- oracleType = OracleType.Char;
- ociType = OciDataType.Char;
- break;
- case DbType.Binary:
- case DbType.Guid:
- oracleType = OracleType.Raw;
- ociType = OciDataType.Raw;
- break;
- case DbType.Boolean:
- case DbType.Byte:
- oracleType = OracleType.Byte;
- ociType = OciDataType.Integer;
- break;
- case DbType.Currency:
- case DbType.Decimal:
- case DbType.Int64:
- oracleType = OracleType.Number;
- ociType = OciDataType.Number;
- break;
- case DbType.Date:
- case DbType.DateTime:
- case DbType.Time:
- oracleType = OracleType.DateTime;
- ociType = OciDataType.Char;
- break;
- case DbType.Double:
- oracleType = OracleType.Double;
- ociType = OciDataType.Float;
- break;
- case DbType.Int16:
- oracleType = OracleType.Int16;
- ociType = OciDataType.Integer;
- break;
- case DbType.Int32:
- oracleType = OracleType.Int32;
- ociType = OciDataType.Integer;
- break;
- case DbType.Object:
- oracleType = OracleType.Blob;
- ociType = OciDataType.Blob;
- break;
- case DbType.Single:
- oracleType = OracleType.Float;
- ociType = OciDataType.Float;
- break;
- case DbType.String:
- oracleType = OracleType.NVarChar;
- ociType = OciDataType.VarChar;
- break;
- case DbType.StringFixedLength:
- oracleType = OracleType.NChar;
- ociType = OciDataType.Char;
- break;
- default:
- throw new ArgumentException (exception);
- }
- dbType = type;
- }
- private void SetOracleType (OracleType type)
- {
- string exception = String.Format ("No mapping exists from OracleType {0} to a known DbType.", type);
- switch (type) {
- case OracleType.BFile:
- case OracleType.Blob:
- case OracleType.LongRaw:
- case OracleType.Raw:
- dbType = DbType.Binary;
- ociType = OciDataType.Raw;
- break;
- case OracleType.Byte:
- dbType = DbType.Byte;
- ociType = OciDataType.Integer;
- break;
- case OracleType.Char:
- dbType = DbType.AnsiStringFixedLength;
- ociType = OciDataType.Char;
- break;
- case OracleType.Clob:
- case OracleType.LongVarChar:
- case OracleType.RowId:
- case OracleType.VarChar:
- dbType = DbType.AnsiString;
- ociType = OciDataType.VarChar;
- break;
- case OracleType.Cursor:
- case OracleType.IntervalDayToSecond:
- dbType = DbType.Object;
- ociType = OciDataType.Blob;
- break;
- case OracleType.DateTime:
- case OracleType.Timestamp:
- case OracleType.TimestampLocal:
- case OracleType.TimestampWithTZ:
- dbType = DbType.DateTime;
- ociType = OciDataType.Char;
- break;
- case OracleType.Double:
- dbType = DbType.Double;
- ociType = OciDataType.Float;
- break;
- case OracleType.Float:
- dbType = DbType.Single;
- ociType = OciDataType.Float;
- break;
- case OracleType.Int16:
- dbType = DbType.Int16;
- ociType = OciDataType.Integer;
- break;
- case OracleType.Int32:
- case OracleType.IntervalYearToMonth:
- dbType = DbType.Int32;
- ociType = OciDataType.Integer;
- break;
- case OracleType.NChar:
- dbType = DbType.StringFixedLength;
- ociType = OciDataType.Char;
- break;
- case OracleType.NClob:
- case OracleType.NVarChar:
- dbType = DbType.String;
- ociType = OciDataType.VarChar;
- break;
- case OracleType.Number:
- dbType = DbType.VarNumeric;
- ociType = OciDataType.Number;
- break;
- case OracleType.SByte:
- dbType = DbType.SByte;
- ociType = OciDataType.Integer;
- break;
- case OracleType.UInt16:
- dbType = DbType.UInt16;
- ociType = OciDataType.Integer;
- break;
- case OracleType.UInt32:
- dbType = DbType.UInt32;
- ociType = OciDataType.Integer;
- break;
- default:
- throw new ArgumentException (exception);
- }
- oracleType = type;
- }
- public override string ToString ()
- {
- return ParameterName;
- }
- #endregion // Methods
- internal sealed class OracleParameterConverter : ExpandableObjectConverter
- {
- public OracleParameterConverter ()
- {
- }
- [MonoTODO]
- public override bool CanConvertTo (ITypeDescriptorContext context, Type destinationType)
- {
- throw new NotImplementedException ();
- }
- [MonoTODO]
- public override object ConvertTo (ITypeDescriptorContext context, CultureInfo culture, object value, Type destinationType)
- {
- throw new NotImplementedException ();
- }
- }
- }
- }
|