Database Access Activities
This topic applies to Windows Workflow Foundation 4 (WF4).
Database access activities allow you to access a database within a workflow. These activities allow accessing databases to retrieve or modify information and use ADO.NET to access the database.
Note: |
---|
The samples may already be installed on your computer. Check for the following (default) directory before continuing.
<InstallDrive>:\WF_WCF_Samples
If this directory does not exist, go to (download page) to download all Windows Communication Foundation (WCF) and WF samples. This sample is located in the following directory.
<InstallDrive>:\WF_WCF_Samples\WF\Scenario\ActivityLibrary\DbActivities
|
Database Activities
The following sections detail the list of activities included in this sample.
DbUpdate
Executes a SQL query that produces a modification in the database (insert, update, delete, and other modifications).
This class performs its work asynchronously (it derives from AsyncCodeActivity and uses its asynchronous capabilities).
The connection information can be configured by setting a provider invariant name (ProviderName
) and the connection string (ConnectionString
) or just using a connection string configuration name (ConfigFileSectionName
) from the application configuration file.
The query to be executed is configured in its Sql
property and the parameters are passed through the Parameters
collection.
After DbUpdate
is executed, the number of affected records is returned in the AffectedRecords
property.
Public class DbUpdate: AsyncCodeActivity
{
[RequiredArgument]
[OverloadGroup("ConnectionString")]
[DefaultValue(null)]
public InArgument<string> ProviderName { get; set; }
[RequiredArgument]
[OverloadGroup("ConnectionString")]
[DependsOn("ProviderName")]
[DefaultValue(null)]
public InArgument<string> ConnectionString { get; set; }
[RequiredArgument]
[OverloadGroup("ConfigFileSectionName")]
[DefaultValue(null)]
public InArgument<string> ConfigName { get; set; }
[DefaultValue(null)]
public CommandType CommandType { get; set; }
[RequiredArgument]
public InArgument<string> Sql { get; set; }
[DependsOn("Sql")]
[DefaultValue(null)]
public IDictionary<string, Argument> Parameters { get; }
[DependsOn("Parameters")]
public OutArgument<int> AffectedRecords { get; set; }
}
Argument |
Description |
ProviderName |
ADO.NET provider invariant name. If this argument is set, then the |
ConnectionString |
Connection string to connect to the database. If this argument is set, then |
ConfigName |
Name of the configuration file section where the connection information is stored. When this argument is set |
CommandType |
Type of the DbCommand to be executed. |
Sql |
The SQL command to be executed. |
Parameters |
Collection of the parameters of the SQL query. |
AffectedRecords |
Number of records affected by the last operation. |
DbQueryScalar
Executes a query that retrieves a single value from the database.
This class performs its work asynchronously (it derives from AsyncCodeActivity and uses its asynchronous capabilities).
The connection information can be configured by setting a provider invariant name (ProviderName
) and the connection string (ConnectionString
) or just using a connection string configuration name (ConfigFileSectionName
) from the application configuration file.
The query to be executed is configured in its Sql
property and the parameters are passed through the Parameters
collection.
After DbQueryScalar
is executed, the scalar is returned in the Result
out argument (of type TResult
, that is defined in the base class AsyncCodeActivity).
public class DbQueryScalar<TResult> : AsyncCodeActivity<TResult>
{
// public arguments
[RequiredArgument]
[OverloadGroup("ConnectionString")]
[DefaultValue(null)]
public InArgument<string> ProviderName { get; set; }
[RequiredArgument]
[OverloadGroup("ConnectionString")]
[DependsOn("ProviderName")]
[DefaultValue(null)]
public InArgument<string> ConnectionString { get; set; }
[RequiredArgument]
[OverloadGroup("ConfigFileSectionName")]
[DefaultValue(null)]
public InArgument<string> ConfigName { get; set; }
[DefaultValue(null)]
public CommandType CommandType { get; set; }
[RequiredArgument]
public InArgument<string> Sql { get; set; }
[DependsOn("Sql")]
[DefaultValue(null)]
public IDictionary<string, Argument> Parameters { get; }
}
Argument |
Description |
ProviderName |
ADO.NET provider invariant name. If this argument is set, then the |
ConnectionString |
Connection string to connect to the database. If this argument is set, then |
ConfigName |
Name of the configuration file section where the connection information is stored. When this argument is set |
CommandType |
Type of the DbCommand to be executed. |
Sql |
The SQL command to be executed. |
Parameters |
Collection of the parameters of the SQL query. |
Result |
Scalar that is obtained after the query is executed. This argument is of type |
DbQuery
Executes a query that retrieves a list of objects. After the query is executed, a mapping function is executed (it can be Func<DbDataReader
, TResult
> or an ActivityFunc<DbDataReader
, TResult
>). This mapping function gets a record in a DbDataReader
and maps it to the object to be returned.
The connection information can be configured by setting a provider invariant name (ProviderName
) and the connection string (ConnectionString
) or just using a connection string configuration name (ConfigFileSectionName
) from the application configuration file.
The query to be executed is configured in its Sql
property and the parameters are passed through the Parameters
collection.
The results of the SQL query are retrieved using a DbDataReader
. The activity iterates through the DbDataReader
and maps the rows in the DbDataReader
to an instance of TResult
. The user of DbQuery
has to provide the mapping code and this can be done in two ways: using a Func<DbDataReader
, TResult
> or an ActivityFunc<DbDataReader
, TResult
>. In the first case, the map is done in a single pulse of execution. Therefore, it is faster, but this cannot be serialized to XAML. In the last case, the map is performed in multiple pulses. Therefore, it might be slower but can be serialized to XAML and authored declaratively (any existing activity can participate in the mapping).
public class DbQuery<TResult> : AsyncCodeActivity<IList<TResult>> where TResult : class
{
// public arguments
[RequiredArgument]
[OverloadGroup("ConnectionString")]
[DefaultValue(null)]
public InArgument<string> ProviderName { get; set; }
[RequiredArgument]
[OverloadGroup("ConnectionString")]
[DependsOn("ProviderName")]
[DefaultValue(null)]
public InArgument<string> ConnectionString { get; set; }
[RequiredArgument]
[OverloadGroup("ConfigFileSectionName")]
[DefaultValue(null)]
public InArgument<string> ConfigName { get; set; }
[DefaultValue(null)]
public CommandType CommandType { get; set; }
[RequiredArgument]
public InArgument<string> Sql { get; set; }
[DependsOn("Sql")]
[DefaultValue(null)]
public IDictionary<string, Argument> Parameters { get; }
[OverloadGroup("DirectMapping")]
[DefaultValue(null)]
public Func<DbDataReader, TResult> Mapper { get; set; }
[OverloadGroup("MultiplePulseMapping")]
[DefaultValue(null)]
public ActivityFunc<DbDataReader, TResult> MapperFunc { get; set; }
}
Argument |
Description |
ProviderName |
ADO.NET provider invariant name. If this argument is set, then the |
ConnectionString |
Connection string to connect to the database. If this argument is set, then |
ConfigName |
Name of the configuration file section where the connection information is stored. When this argument is set |
CommandType |
Type of the DbCommand to be executed. |
Sql |
The SQL command to be executed. |
Parameters |
Collection of the parameters of the SQL query. |
Mapper |
Mapping function (Func< In this case, mapping is done in a single pulse of execution, but it cannot be authored declaratively using the designer. |
MapperFunc |
Mapping function (ActivityFunc< In this case, the mapping is done in multiple pulses of execution. This function can be serialized to XAML and authored declaratively (any existing activity can participate in the mapping). |
Result |
List of objects obtained as result of executing the query and executing the mapping function for each record in the |
DbQueryDataSet
Executes a query that returns a DataSet. This class performs its work asynchronously. It derives from AsyncCodeActivity<TResult
> and uses its asynchronous capabilities.
The connection information can be configured by setting a provider invariant name (ProviderName
) and the connection string (ConnectionString
) or just using a connection string configuration name (ConfigFileSectionName
) from the application configuration file.
The query to be executed is configured in its Sql
property and the parameters are passed through the Parameters
collection.
After the DbQueryDataSet
is executed the DataSet
is returned in the Result
out argument (of type TResult
, that is defined in the base class AsyncCodeActivity).
public class DbQueryDataSet : AsyncCodeActivity<DataSet>
{
// public arguments
[RequiredArgument]
[OverloadGroup("ConnectionString")]
[DefaultValue(null)]
public InArgument<string> ProviderName { get; set; }
[RequiredArgument]
[OverloadGroup("ConnectionString")]
[DependsOn("ProviderName")]
[DefaultValue(null)]
public InArgument<string> ConnectionString { get; set; }
[RequiredArgument]
[OverloadGroup("ConfigFileSectionName")]
[DefaultValue(null)]
public InArgument<string> ConfigName { get; set; }
[DefaultValue(null)]
public CommandType CommandType { get; set; }
[RequiredArgument]
public InArgument<string> Sql { get; set; }
[DependsOn("Sql")]
[DefaultValue(null)]
public IDictionary<string, Argument> Parameters { get; }
}
Argument |
Description |
ProviderName |
ADO.NET provider invariant name. If this argument is set, then the |
ConnectionString |
Connection string to connect to the database. If this argument is set, then |
ConfigName |
Name of the configuration file section where the connection information is stored. When this argument is set |
CommandType |
Type of the DbCommand to be executed. |
Sql |
The SQL command to be executed. |
Parameters |
Collection of the parameters of the SQL query. |
Result |
DataSet that is obtained after the query is executed. |
Configuring Connection Information
All DbActivities share the same configuration parameters. They can be configured in two ways:
ConnectionString + InvariantName: Set the ADO.NET provider invariant name and connection string.
Activity dbSelectCount = new DbQueryScalar<DateTime>() { ProviderName = "System.Data.SqlClient", ConnectionString = @"Data Source=.\SQLExpress; Initial Catalog=DbActivitiesSample; Integrated Security=True", Sql = "SELECT GetDate()" };
ConfigName: Set the name of the configuration section that contains the connection information.
<connectionStrings> <add name="DbActivitiesSample" providerName="System.Data.SqlClient" connectionString="Data Source=.\SQLExpress;Initial Catalog=DbActivitiesSample;Integrated Security=true"/> </connectionStrings>
In the activity:
Activity dbSelectCount = new DbQueryScalar<int>() { ConfigName = "DbActivitiesSample", Sql = "SELECT COUNT(*) FROM Roles" };
Running this sample
Setup instructions
This sample uses a database. A set-up and load script (Setup.cmd) is provided with the sample. You must execute that file using the command prompt.
The Setup.cmd script invokes the CreateDb.sql script file, which contains SQL commands that do the following:
Creates a database called DbActivitiesSample.
Creates the Roles table.
Creates Employees table.
Inserts three records into the Roles table.
Inserts twelve records into the Employees table.
To run Setup.cmd
Open a command prompt.
Go to the DbActivities sample folder.
Type “setup.cmd” and press ENTER.
Note
Setup.cmd attempts to install the sample in your local computer SqlExpress instance. If you want to install it in other SQL server instance, edit Setup.cmd with the new instance name.
To uninstall the sample database
- Run Cleanup.cmd from the sample folder in a command prompt.
To run the sample
Open the solution in Visual Studio 2010
To compile the solution, press CTRL+SHIFT+B.
To run the sample without debugging, press CTRL+F5.
Note: |
---|
The samples may already be installed on your computer. Check for the following (default) directory before continuing.
<InstallDrive>:\WF_WCF_Samples
If this directory does not exist, go to Windows Communication Foundation (WCF) and Windows Workflow Foundation (WF) Samples for .NET Framework 4 to download all Windows Communication Foundation (WCF) and WF samples. This sample is located in the following directory.
<InstallDrive>:\WF_WCF_Samples\WF\Scenario\ActivityLibrary\DbActivities
|