SqlParameter.cs 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337
  1. //
  2. // System.Data.SqlClient.SqlParameter.cs
  3. //
  4. // Author:
  5. // Rodrigo Moya ([email protected])
  6. // Daniel Morgan ([email protected])
  7. // Tim Coleman ([email protected])
  8. //
  9. // (C) Ximian, Inc. 2002
  10. // Copyright (C) Tim Coleman, 2002
  11. //
  12. using System;
  13. using System.ComponentModel;
  14. using System.Data;
  15. using System.Data.Common;
  16. using System.Runtime.InteropServices;
  17. using System.Text;
  18. namespace System.Data.SqlClient {
  19. /// <summary>
  20. /// Represents a parameter to a Command object, and optionally,
  21. /// its mapping to DataSet columns; and is implemented by .NET
  22. /// data providers that access data sources.
  23. /// </summary>
  24. public sealed class SqlParameter : MarshalByRefObject, IDbDataParameter, IDataParameter, ICloneable
  25. {
  26. #region Fields
  27. string parmName;
  28. SqlDbType dbtype;
  29. DbType theDbType;
  30. object objValue;
  31. int size;
  32. string sourceColumn;
  33. ParameterDirection direction = ParameterDirection.Input;
  34. bool isNullable;
  35. byte precision;
  36. byte scale;
  37. DataRowVersion sourceVersion;
  38. int offset;
  39. bool sizeSet = false;
  40. #endregion // Fields
  41. #region Constructors
  42. public SqlParameter ()
  43. : this (String.Empty, SqlDbType.NVarChar, 0, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, null)
  44. {
  45. }
  46. public SqlParameter (string parameterName, object value)
  47. : this (parameterName, SqlDbType.NVarChar, 0, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, value)
  48. {
  49. }
  50. public SqlParameter (string parameterName, SqlDbType dbType)
  51. : this (parameterName, dbType, 0, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, null)
  52. {
  53. }
  54. public SqlParameter (string parameterName, SqlDbType dbType, int size)
  55. : this (parameterName, dbType, size, ParameterDirection.Input, false, 0, 0, String.Empty, DataRowVersion.Current, null)
  56. {
  57. }
  58. public SqlParameter (string parameterName, SqlDbType dbType, int size, string sourceColumn)
  59. : this (parameterName, dbType, size, ParameterDirection.Input, false, 0, 0, sourceColumn, DataRowVersion.Current, null)
  60. {
  61. }
  62. [EditorBrowsable (EditorBrowsableState.Advanced)]
  63. public SqlParameter (string parameterName, SqlDbType dbType, int size, ParameterDirection direction, bool isNullable, byte precision, byte scale, string sourceColumn, DataRowVersion sourceVersion, object value)
  64. {
  65. this.parmName = parameterName;
  66. this.dbtype = dbType;
  67. this.size = size;
  68. this.sourceColumn = sourceColumn;
  69. this.direction = direction;
  70. this.isNullable = isNullable;
  71. this.precision = precision;
  72. this.scale = scale;
  73. this.sourceVersion = sourceVersion;
  74. this.objValue = value;
  75. }
  76. internal SqlParameter (object[] dbValues)
  77. {
  78. precision = 0;
  79. scale = 0;
  80. direction = ParameterDirection.Input;
  81. parmName = (string) dbValues[3];
  82. switch ((short) dbValues[5]) {
  83. case 1:
  84. direction = ParameterDirection.Input;
  85. break;
  86. case 2:
  87. direction = ParameterDirection.Output;
  88. break;
  89. case 3:
  90. direction = ParameterDirection.InputOutput;
  91. break;
  92. case 4:
  93. direction = ParameterDirection.ReturnValue;
  94. break;
  95. }
  96. isNullable = (bool) dbValues[8];
  97. if (dbValues[12] != null)
  98. precision = (byte) ((short) dbValues[12]);
  99. if (dbValues[13] != null)
  100. scale = (byte) ((short) dbValues[13]);
  101. dbtype = TypeNameToSqlDbType ((string) dbValues[16]);
  102. }
  103. #endregion // Constructors
  104. #region Properties
  105. [Browsable (false)]
  106. [DataCategory ("Data")]
  107. [DataSysDescription ("The parameter generic type.")]
  108. [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)]
  109. [RefreshProperties (RefreshProperties.All)]
  110. public DbType DbType {
  111. get { return theDbType; }
  112. set { theDbType = value; }
  113. }
  114. [DataCategory ("Data")]
  115. [DataSysDescription ("Input, output, or bidirectional parameter.")]
  116. [DefaultValue (ParameterDirection.Input)]
  117. public ParameterDirection Direction {
  118. get { return direction; }
  119. set { direction = value; }
  120. }
  121. string IDataParameter.ParameterName {
  122. get { return parmName; }
  123. set { parmName = value; }
  124. }
  125. [Browsable (false)]
  126. [DataSysDescription ("a design-time property used for strongly typed code-generation.")]
  127. [DefaultValue (false)]
  128. [DesignOnly (true)]
  129. [EditorBrowsable (EditorBrowsableState.Advanced)]
  130. public bool IsNullable {
  131. get { return isNullable; }
  132. set { isNullable = value; }
  133. }
  134. [Browsable (false)]
  135. [DataCategory ("Data")]
  136. [DataSysDescription ("Offset in variable length data types.")]
  137. [DefaultValue (0)]
  138. public int Offset {
  139. get { return offset; }
  140. set { offset = value; }
  141. }
  142. [DataSysDescription ("Name of the parameter, like '@p1'")]
  143. [DefaultValue ("")]
  144. public string ParameterName {
  145. get { return parmName; }
  146. set { parmName = value; }
  147. }
  148. [DataCategory ("Data")]
  149. [DataSysDescription ("For decimal, numeric, varnumeric DBTypes.")]
  150. [DefaultValue (0)]
  151. public byte Precision {
  152. get { return precision; }
  153. set { precision = value; }
  154. }
  155. [DataCategory ("Data")]
  156. [DataSysDescription ("For decimal, numeric, varnumeric DBTypes.")]
  157. [DefaultValue (0)]
  158. public byte Scale {
  159. get { return scale; }
  160. set { scale = value; }
  161. }
  162. [DataCategory ("Data")]
  163. [DataSysDescription ("Size of variable length datatypes (strings & arrays).")]
  164. [DefaultValue (0)]
  165. public int Size {
  166. get { return size; }
  167. set {
  168. sizeSet = true;
  169. size = value;
  170. }
  171. }
  172. [DataCategory ("Data")]
  173. [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.")]
  174. [DefaultValue ("")]
  175. public string SourceColumn {
  176. get { return sourceColumn; }
  177. set { sourceColumn = value; }
  178. }
  179. [DataCategory ("Data")]
  180. [DataSysDescription ("When used by a DataAdapter.Update (UpdateCommand only), the version of the DataRow value that is used to update the data source.")]
  181. [DefaultValue (DataRowVersion.Current)]
  182. public DataRowVersion SourceVersion {
  183. get { return sourceVersion; }
  184. set { sourceVersion = value; }
  185. }
  186. [DataCategory ("Data")]
  187. [DataSysDescription ("The parameter native type.")]
  188. [DefaultValue (SqlDbType.NVarChar)]
  189. [RefreshProperties (RefreshProperties.All)]
  190. public SqlDbType SqlDbType {
  191. get { return dbtype; }
  192. set { dbtype = value; }
  193. }
  194. [DataCategory ("Data")]
  195. [DataSysDescription ("Value of the parameter.")]
  196. [DefaultValue (null)]
  197. public object Value {
  198. get { return objValue; }
  199. set { objValue = value; }
  200. }
  201. #endregion // Properties
  202. #region Methods
  203. object ICloneable.Clone ()
  204. {
  205. return new SqlParameter (ParameterName, SqlDbType, Size, Direction, IsNullable, Precision, Scale, SourceColumn, SourceVersion, Value);
  206. }
  207. internal string Prepare (string name)
  208. {
  209. StringBuilder result = new StringBuilder ();
  210. result.Append (name);
  211. result.Append (" ");
  212. result.Append (dbtype.ToString ().ToLower ());
  213. switch (dbtype) {
  214. case SqlDbType.Image :
  215. case SqlDbType.NVarChar :
  216. case SqlDbType.VarBinary :
  217. case SqlDbType.VarChar :
  218. if (!sizeSet || size == 0)
  219. throw new InvalidOperationException ("All variable length parameters must have an explicitly set non-zero size.");
  220. result.Append ("(");
  221. result.Append (size.ToString ());
  222. result.Append (")");
  223. break;
  224. case SqlDbType.Decimal :
  225. case SqlDbType.Money :
  226. case SqlDbType.SmallMoney :
  227. result.Append ("(");
  228. result.Append (precision.ToString ());
  229. result.Append (",");
  230. result.Append (scale.ToString ());
  231. result.Append (")");
  232. break;
  233. default:
  234. break;
  235. }
  236. return result.ToString ();
  237. }
  238. internal static SqlDbType TypeNameToSqlDbType (string typeName)
  239. {
  240. switch (typeName) {
  241. case "bigint":
  242. return SqlDbType.BigInt;
  243. case "binary":
  244. return SqlDbType.Binary;
  245. case "bit":
  246. return SqlDbType.Bit;
  247. case "char":
  248. return SqlDbType.Char;
  249. case "datetime":
  250. return SqlDbType.DateTime;
  251. case "decimal":
  252. return SqlDbType.Decimal;
  253. case "float":
  254. return SqlDbType.Float;
  255. case "image":
  256. return SqlDbType.Image;
  257. case "int":
  258. return SqlDbType.Int;
  259. case "money":
  260. return SqlDbType.Money;
  261. case "nchar":
  262. return SqlDbType.NChar;
  263. case "ntext":
  264. return SqlDbType.NText;
  265. case "nvarchar":
  266. return SqlDbType.NVarChar;
  267. case "real":
  268. return SqlDbType.Real;
  269. case "smalldatetime":
  270. return SqlDbType.SmallDateTime;
  271. case "smallint":
  272. return SqlDbType.SmallInt;
  273. case "smallmoney":
  274. return SqlDbType.SmallMoney;
  275. case "text":
  276. return SqlDbType.Text;
  277. case "timestamp":
  278. return SqlDbType.Timestamp;
  279. case "tinyint":
  280. return SqlDbType.TinyInt;
  281. case "uniqueidentifier":
  282. return SqlDbType.UniqueIdentifier;
  283. case "varbinary":
  284. return SqlDbType.VarBinary;
  285. case "varchar":
  286. return SqlDbType.VarChar;
  287. }
  288. return SqlDbType.Variant;
  289. }
  290. public override string ToString()
  291. {
  292. return parmName;
  293. }
  294. #endregion // Methods
  295. }
  296. }