| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327 |
- //
- // System.Data.SqlClient.SqlParameter.cs
- //
- // Author:
- // Rodrigo Moya ([email protected])
- // Daniel Morgan ([email protected])
- // Tim Coleman ([email protected])
- //
- // (C) Ximian, Inc. 2002
- // Copyright (C) Tim Coleman, 2002
- //
- using System;
- using System.ComponentModel;
- using System.Data;
- using System.Data.Common;
- using System.Runtime.InteropServices;
- using System.Text;
- namespace System.Data.SqlClient {
- /// <summary>
- /// Represents a parameter to a Command object, and optionally,
- /// its mapping to DataSet columns; and is implemented by .NET
- /// data providers that access data sources.
- /// </summary>
- public sealed class SqlParameter : MarshalByRefObject, IDbDataParameter, IDataParameter, ICloneable
- {
- #region Fields
- string parmName;
- SqlDbType dbtype;
- DbType theDbType;
- object objValue;
- int size;
- string sourceColumn;
- ParameterDirection direction = ParameterDirection.Input;
- bool isNullable;
- byte precision;
- byte scale;
- DataRowVersion sourceVersion;
- int offset;
- bool sizeSet = false;
- #endregion // Fields
- #region Constructors
- public SqlParameter ()
- : this (String.Empty, SqlDbType.NVarChar, 0, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, null)
- {
- }
- public SqlParameter (string parameterName, object value)
- : this (parameterName, SqlDbType.NVarChar, 0, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, value)
- {
- }
-
- public SqlParameter (string parameterName, SqlDbType dbType)
- : this (parameterName, dbType, 0, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, null)
- {
- }
- public SqlParameter (string parameterName, SqlDbType dbType, int size)
- : this (parameterName, dbType, size, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, null)
- {
- }
-
- public SqlParameter (string parameterName, SqlDbType dbType, int size, string sourceColumn)
- : this (parameterName, dbType, size, ParameterDirection.Input, false, 0, 0, sourceColumn, DataRowVersion.Current, null)
- {
- }
-
- [EditorBrowsable (EditorBrowsableState.Advanced)]
- public SqlParameter (string parameterName, SqlDbType dbType, int size, ParameterDirection direction, bool isNullable, byte precision, byte scale, string sourceColumn, DataRowVersion sourceVersion, object value)
- {
- this.parmName = parameterName;
- this.dbtype = dbType;
- this.size = size;
- this.sourceColumn = sourceColumn;
- this.direction = direction;
- this.isNullable = isNullable;
- this.precision = precision;
- this.scale = scale;
- this.sourceVersion = sourceVersion;
- this.objValue = value;
- }
- internal SqlParameter (object[] dbValues)
- {
- precision = 0;
- scale = 0;
- direction = ParameterDirection.Input;
- parmName = (string) dbValues[3];
- switch ((short) dbValues[5]) {
- case 1:
- direction = ParameterDirection.Input;
- break;
- case 2:
- direction = ParameterDirection.Output;
- break;
- case 3:
- direction = ParameterDirection.InputOutput;
- break;
- case 4:
- direction = ParameterDirection.ReturnValue;
- break;
- }
- isNullable = (bool) dbValues[8];
- if (dbValues[12] != null)
- precision = (byte) ((short) dbValues[12]);
- if (dbValues[13] != null)
- scale = (byte) ((short) dbValues[13]);
- dbtype = TypeNameToSqlDbType ((string) dbValues[16]);
- }
- #endregion // Constructors
- #region Properties
- [Browsable (false)]
- [DataSysDescription ("The parameter generic type.")]
- [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)]
- //[RefreshProperties (RefreshProperties.All)]
- public DbType DbType {
- get { return theDbType; }
- set { theDbType = value; }
- }
- [DataSysDescription ("Input, output, or bidirectional parameter.")]
- [DefaultValue (ParameterDirection.Input)]
- public ParameterDirection Direction {
- get { return direction; }
- set { direction = value; }
- }
- [Browsable (false)]
- [DataSysDescription ("a design-time property used for strongly typed code-generation.")]
- [DefaultValue (false)]
- [DesignOnly (true)]
- [EditorBrowsable (EditorBrowsableState.Advanced)]
- public bool IsNullable {
- get { return isNullable; }
- }
- [Browsable (false)]
- [DataSysDescription ("Offset in variable length data types.")]
- [DefaultValue (0)]
- public int Offset {
- get { return offset; }
- set { offset = value; }
- }
-
- string IDataParameter.ParameterName {
- get { return parmName; }
- set { parmName = value; }
- }
-
- [DataSysDescription ("Name of the parameter, like '@p1'")]
- [DefaultValue ("")]
- public string ParameterName {
- get { return parmName; }
- set { parmName = value; }
- }
- [DataSysDescription ("For decimal, numeric, varnumeric DBTypes.")]
- [DefaultValue (0)]
- public byte Precision {
- get { return precision; }
- set { precision = value; }
- }
- [DataSysDescription ("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.")]
- [DefaultValue ("")]
- public string SourceColumn {
- get { return sourceColumn; }
- set { sourceColumn = value; }
- }
- [DataSysDescription ("When used by a DataAdapter.Update (UpdateCommand only), the version of the DataRow value that is used to update the data source.")]
- [DefaultValue (DataRowVersion.Current)]
- public DataRowVersion SourceVersion {
- get { return sourceVersion; }
- set { sourceVersion = value; }
- }
-
- [DataSysDescription ("The parameter native type.")]
- [DefaultValue (SqlDbType.NVarChar)]
- //[RefreshProperties (RefreshProperties.All)]
- public SqlDbType SqlDbType {
- get { return dbtype; }
- set { dbtype = value; }
- }
- [DataSysDescription ("Value of the parameter.")]
- [DefaultValue (null)]
- public object Value {
- get { return objValue; }
- set { objValue = value; }
- }
- [DataSysDescription ("For decimal, numeric, varnumeric DBTypes.")]
- [DefaultValue (0)]
- public byte Scale {
- get { return scale; }
- set { scale = value; }
- }
- [DataSysDescription ("Size of variable length datatypes (strings & arrays).")]
- [DefaultValue (0)]
- public int Size {
- get { return size; }
- set {
- sizeSet = true;
- size = value;
- }
- }
- #endregion // Properties
- #region Methods
- [MonoTODO]
- object ICloneable.Clone ()
- {
- throw new NotImplementedException ();
- }
- internal string Prepare (string name)
- {
- StringBuilder result = new StringBuilder ();
- result.Append (name);
- result.Append (" ");
- result.Append (dbtype.ToString ().ToLower ());
- switch (dbtype) {
- case SqlDbType.Image :
- case SqlDbType.NVarChar :
- case SqlDbType.VarBinary :
- case SqlDbType.VarChar :
- if (!sizeSet || size == 0)
- throw new InvalidOperationException ("All variable length parameters must have an explicitly set non-zero size.");
- result.Append ("(");
- result.Append (size.ToString ());
- result.Append (")");
- break;
- case SqlDbType.Decimal :
- case SqlDbType.Money :
- case SqlDbType.SmallMoney :
- result.Append ("(");
- result.Append (precision.ToString ());
- result.Append (",");
- result.Append (scale.ToString ());
- result.Append (")");
- break;
- default:
- break;
- }
- return result.ToString ();
- }
- internal static SqlDbType TypeNameToSqlDbType (string typeName)
- {
- switch (typeName) {
- case "bigint":
- return SqlDbType.BigInt;
- case "binary":
- return SqlDbType.Binary;
- case "bit":
- return SqlDbType.Bit;
- case "char":
- return SqlDbType.Char;
- case "datetime":
- return SqlDbType.DateTime;
- case "decimal":
- return SqlDbType.Decimal;
- case "float":
- return SqlDbType.Float;
- case "image":
- return SqlDbType.Image;
- case "int":
- return SqlDbType.Int;
- case "money":
- return SqlDbType.Money;
- case "nchar":
- return SqlDbType.NChar;
- case "ntext":
- return SqlDbType.NText;
- case "nvarchar":
- return SqlDbType.NVarChar;
- case "real":
- return SqlDbType.Real;
- case "smalldatetime":
- return SqlDbType.SmallDateTime;
- case "smallint":
- return SqlDbType.SmallInt;
- case "smallmoney":
- return SqlDbType.SmallMoney;
- case "text":
- return SqlDbType.Text;
- case "timestamp":
- return SqlDbType.Timestamp;
- case "tinyint":
- return SqlDbType.TinyInt;
- case "uniqueidentifier":
- return SqlDbType.UniqueIdentifier;
- case "varbinary":
- return SqlDbType.VarBinary;
- case "varchar":
- return SqlDbType.VarChar;
- }
- return SqlDbType.Variant;
- }
- public override string ToString()
- {
- return parmName;
- }
- #endregion // Methods
- }
- }
|