本文整理汇总了C#中System.Data.Common.DbCommand.ExecuteNonQuerySyncOrAsync方法的典型用法代码示例。如果您正苦于以下问题:C# DbCommand.ExecuteNonQuerySyncOrAsync方法的具体用法?C# DbCommand.ExecuteNonQuerySyncOrAsync怎么用?C# DbCommand.ExecuteNonQuerySyncOrAsync使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类System.Data.Common.DbCommand
的用法示例。
在下文中一共展示了DbCommand.ExecuteNonQuerySyncOrAsync方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: CommandExecuteAsync
protected async virtual Task CommandExecuteAsync(Random rnd, DbCommand com, bool query)
{
CancellationTokenSource cts = null;
// Cancel 1/10 commands
Task cancelTask = null;
bool cancelCommand = rnd.NextBool(0.1);
if (cancelCommand)
{
if (rnd.NextBool())
{
// Use DbCommand.Cancel
cancelTask = Task.Run(() => CommandCancel(com));
}
else
{
// Use CancellationTokenSource
if (cts == null) cts = new CancellationTokenSource();
cancelTask = Task.Run(() => cts.Cancel());
}
}
// Get the CancellationToken
CancellationToken token = (cts != null) ? cts.Token : CancellationToken.None;
DataStressReader reader = null;
try
{
if (query)
{
CommandBehavior commandBehavior = CommandBehavior.Default;
if (rnd.NextBool(0.5)) commandBehavior |= CommandBehavior.SequentialAccess;
if (rnd.NextBool(0.25)) commandBehavior |= CommandBehavior.KeyInfo;
if (rnd.NextBool(0.1)) commandBehavior |= CommandBehavior.SchemaOnly;
// Get the reader
reader = new DataStressReader(await com.ExecuteReaderSyncOrAsync(commandBehavior, token, rnd));
// Consume the reader's data
await ConsumeReaderAsync(reader, commandBehavior.HasFlag(CommandBehavior.SequentialAccess), token, rnd);
}
else
{
await com.ExecuteNonQuerySyncOrAsync(token, rnd);
}
}
catch (Exception e)
{
if (cancelCommand && IsCommandCancelledException(e))
{
// Catch command canceled exception
}
else
{
throw;
}
}
finally
{
if (cancelTask != null) AsyncUtils.WaitAndUnwrapException(cancelTask);
if (reader != null && ShouldCloseDataReader()) reader.Close();
}
}