gpt4 book ai didi

c# - SqlDependency - 防止事件之间的数据丢失并再次重新注册查询?

转载 作者:行者123 更新时间:2023-11-30 18:26:51 29 4
gpt4 key购买 nike

我们正在开发一个 WPF 应用程序,使用 SqlDependencies 来根据数据库更新应用程序。我们已经认识到几次,查询通知似乎是不规则的——应用程序不显示数据库的最新状态。一旦其他人更改了桌面上的内容,应用程序就会快速更新并显示最新状态。

我现在已经编写了一个工具,它可以在特定时间内尽可能快地更改数据库,还有一个工具可以注册 SqlDependencies 并计算触发了多少 SqlDependencies。

private void AddNewQuery(string query)
{
using (var connection = new SqlConnection(_connectionString))
{
connection.Open();
var command = new SqlCommand(query, connection);
var dependency = new SqlDependency(command);

dependency.OnChange += OnQueryChanged;
}
}

private void OnQueryChanged(object sender, SqlNotificationEventArgs e)
{
AddNewQuery('SELECT Foo,Bar FROM dbo.Foobar');
OnDatabaseChanged();
var dependency = sender as SqlDependency;
dependency.OnChange -= OnQueryChanged;
}

private void OnDatabaseChanged()
{
lock(_databaseChangedLocker)
_counter++;
}

显然,主应用程序运行得越快,SqlDependency-Reader 识别的通知就越少。例如:我已经运行了几次 1000 个查询:

9.2 秒的总运行时间导致收到 520 条通知 (52%)14 秒的总运行时间导致 822 条通知 (82.2%)19.3 秒的总运行时间导致 957 条通知 (95.7%)。

有没有办法防止这种数据丢失并确保每次更改都会导致 QueryNotification?我们正在运行 SQL Server 2008 R2。

最佳答案

您可能应该在更新 GUI 之前注册新的 SqlDependency。这样您将始终拥有最新状态,无论在此期间发生了多少变化。

关于c# - SqlDependency - 防止事件之间的数据丢失并再次重新注册查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27960176/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com