2 // System.Data.Common.DbCommand
5 // Tim Coleman (tim@timcoleman.com)
7 // Copyright (C) Tim Coleman, 2003
11 // Copyright (C) 2004 Novell, Inc (http://www.novell.com)
13 // Permission is hereby granted, free of charge, to any person obtaining
14 // a copy of this software and associated documentation files (the
15 // "Software"), to deal in the Software without restriction, including
16 // without limitation the rights to use, copy, modify, merge, publish,
17 // distribute, sublicense, and/or sell copies of the Software, and to
18 // permit persons to whom the Software is furnished to do so, subject to
19 // the following conditions:
21 // The above copyright notice and this permission notice shall be
22 // included in all copies or substantial portions of the Software.
24 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
27 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
28 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
29 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
30 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
33 using System.ComponentModel;
36 using System.Threading;
37 using System.Threading.Tasks;
39 namespace System.Data.Common {
40 public abstract class DbCommand : Component, IDbCommand, IDisposable
42 protected DbCommand ()
49 [RefreshProperties (RefreshProperties.All)]
50 public abstract string CommandText { get; set; }
52 public abstract int CommandTimeout { get; set; }
54 [DefaultValue (CommandType.Text)]
55 [RefreshProperties (RefreshProperties.All)]
56 public abstract CommandType CommandType { get; set; }
60 [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)]
61 public DbConnection Connection {
62 get { return DbConnection; }
63 set { DbConnection = value; }
66 protected abstract DbConnection DbConnection { get; set; }
67 protected abstract DbParameterCollection DbParameterCollection { get; }
68 protected abstract DbTransaction DbTransaction { get; set; }
70 [EditorBrowsable (EditorBrowsableState.Never)]
74 public abstract bool DesignTimeVisible { get; set; }
76 IDbConnection IDbCommand.Connection {
77 get { return Connection; }
78 set { Connection = (DbConnection) value; }
81 IDataParameterCollection IDbCommand.Parameters {
82 get { return Parameters; }
85 IDbTransaction IDbCommand.Transaction {
86 get { return Transaction; }
87 set { Transaction = (DbTransaction) value; }
91 [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)]
92 public DbParameterCollection Parameters {
93 get { return DbParameterCollection; }
98 [DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)]
99 public DbTransaction Transaction {
100 get { return DbTransaction; }
101 set { DbTransaction = value; }
104 [DefaultValue (UpdateRowSource.Both)]
105 public abstract UpdateRowSource UpdatedRowSource { get; set; }
107 #endregion // Properties
111 public abstract void Cancel ();
112 protected abstract DbParameter CreateDbParameter ();
114 public DbParameter CreateParameter ()
116 return CreateDbParameter ();
119 protected abstract DbDataReader ExecuteDbDataReader (CommandBehavior behavior);
120 public abstract int ExecuteNonQuery ();
122 public DbDataReader ExecuteReader ()
124 return ExecuteDbDataReader (CommandBehavior.Default);
127 public DbDataReader ExecuteReader (CommandBehavior behavior)
129 return ExecuteDbDataReader (behavior);
132 public abstract object ExecuteScalar ();
134 IDbDataParameter IDbCommand.CreateParameter ()
136 return CreateParameter ();
139 IDataReader IDbCommand.ExecuteReader ()
141 return ExecuteReader ();
144 IDataReader IDbCommand.ExecuteReader (CommandBehavior behavior)
146 return ExecuteReader (behavior);
149 public abstract void Prepare ();
151 protected virtual Task<DbDataReader> ExecuteDbDataReaderAsync (CommandBehavior behavior, CancellationToken cancellationToken)
153 if (cancellationToken.IsCancellationRequested) {
154 return TaskHelper.CreateCanceledTask<DbDataReader> ();
158 return Task.FromResult (ExecuteDbDataReader (behavior));
159 } catch (Exception e) {
160 return TaskHelper.CreateExceptionTask<DbDataReader> (e);
164 public Task<int> ExecuteNonQueryAsync ()
166 return ExecuteNonQueryAsync (CancellationToken.None);
169 public virtual Task<int> ExecuteNonQueryAsync (CancellationToken cancellationToken)
171 if (cancellationToken.IsCancellationRequested) {
172 return TaskHelper.CreateCanceledTask<int> ();
176 return Task.FromResult (ExecuteNonQuery ());
177 } catch (Exception e) {
178 return TaskHelper.CreateExceptionTask<int> (e);
182 public Task<Object> ExecuteScalarAsync ()
184 return ExecuteScalarAsync (CancellationToken.None);
187 public virtual Task<Object> ExecuteScalarAsync (CancellationToken cancellationToken)
189 if (cancellationToken.IsCancellationRequested) {
190 return TaskHelper.CreateCanceledTask<Object> ();
194 return Task.FromResult (ExecuteScalar ());
195 } catch (Exception e) {
196 return TaskHelper.CreateExceptionTask<Object> (e);
200 public Task<DbDataReader> ExecuteReaderAsync ()
202 return ExecuteReaderAsync (CancellationToken.None);
205 public Task<DbDataReader> ExecuteReaderAsync (CancellationToken cancellationToken)
207 if (cancellationToken.IsCancellationRequested) {
208 return TaskHelper.CreateCanceledTask<DbDataReader> ();
212 return Task.FromResult (ExecuteReader ());
213 } catch (Exception e) {
214 return TaskHelper.CreateExceptionTask<DbDataReader> (e);
218 public Task<DbDataReader> ExecuteReaderAsync (CommandBehavior behavior)
220 return ExecuteReaderAsync (behavior, CancellationToken.None);
223 public Task<DbDataReader> ExecuteReaderAsync (CommandBehavior behavior, CancellationToken cancellationToken)
225 if (cancellationToken.IsCancellationRequested) {
226 return TaskHelper.CreateCanceledTask<DbDataReader> ();
230 return Task.FromResult (ExecuteReader (behavior));
231 } catch (Exception e) {
232 return TaskHelper.CreateExceptionTask<DbDataReader> (e);
237 #endregion // Methods