I need to notify users (around 100 clients) of my software (C#, .NET 3.5) when there are new records added in one of the tables of my database (SQL Server 2008). If I understand it right, such operation should qualify as cache invalidation which is exactly what is SqlDependency
for, please correct me on this one if I'm wrong.
For that I can see 2 options:
SqlDependency
which will allow me to receive practically realtime notifications.- Checking table by some timer.
But I never used SqlDependency
before and have no idea how reliable is it really? I mean, can I allow my application just run SqlDependency.Start()
at the start of a day and be sure it will listen for notifications no matter what for 10 hours? Of course I understand I must correctly react on service query notifications. And is it really better to do so in comparison to query by timer in terms of performance of database? Is there any considerable difference actually for database?
I’m considering using SqlDependency
mostly because I’m not sure it’s a best idea to have all of my users to open connection and query the same table in the same database every 5 minutes.