ich SqlDependecy
mit signalR
bin mit Benachrichtigungen an Client-Browser zu drücken, wenn es einige Datenbankänderungen ist, folgte ich this und this Post und alles funktioniert in lokaler SqlExpress
Version 11.0 mit Local Connection String, aber ich habe eine Art von Berechtigungen Problem, wenn ich auf Remote-Datenbank in GoDaddy mit Produktions Connection StringKann nicht das Objekt „QueryNotificationErrorsQueue“ finden, weil es nicht oder Sie haben existiert keine Berechtigungen
Arbeits lokalen Connection
gehostet verbinden 210Produktion Connection
<add name="NotifyConnection" connectionString="Server=000.00.00.000;Database=TestDB;
User Id=UserName;Password=YourPassword;" providerName="System.Data.SqlClient" />
Daten Methode Get
public IEnumerable<Order> GetData()
{
using (var connection = new SqlConnection(ConfigurationManager.ConnectionStrings
["NotifyConnection"].ConnectionString))
{
using (SqlCommand command = connection.CreateCommand())
{
command.CommandType = CommandType.Text;
command.CommandText = "SELECT OrderID,CustomerID FROM dbo.[RestUser]";
command.Notification = null;
SqlDependency dependency = new SqlDependency(command);
dependency.OnChange += new OnChangeEventHandler(dependency_OnChange);
if (connection.State == ConnectionState.Closed)
connection.Open();
using (var reader = command.ExecuteReader())
return reader.Cast<IDataRecord>() // Here the Error throws
.Select(x => new Order()
{
OrderID = x.GetInt32(0),
CustomerID = x.GetInt32(1)
}).ToList();
}
}
}
Was ich versucht habe?
Ich folgte diesem post, um Berechtigungen in SQL Server zu gewähren, aber nicht sicher ist diese korrekte Methode zu folgen.
USE YourDatabaseName;
CREATE QUEUE NameChangeQueue;
CREATE SERVICE NameChangeService ON QUEUE NameChangeQueue ([http://schemas.microsoft.com/
SQL/Notifications/PostQueryNotification]);
GRANT SUBSCRIBE QUERY NOTIFICATIONS TO YourUserName; // Here i get this error:
//Cannot grant, deny, or revoke permissions to sa, dbo, entity owner, information_schema,
sys, or yourself.
ALTER DATABASE YourDatabaseName SET ENABLE_BROKER; // Broker is already enabled
Screen Shot:
Ich bin neu in SqlDependency
, wie dieses Problem zu beheben?
Jede Hilfe wäre großartig.
Überprüfen Sie die Netzwerk- und Authentifizierungsüberlegungen in [dieser Antwort] (http://stackoverflow.com/a/8316200/707618). Außerdem rufen Sie in Ihrem Code ['SqlDependency.Start()'] (https://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqldependency.start (v = vs.110) .aspx)? – Smudge202
@ Smudge202 Danke für den Kommentar, ich rufe es in 'Appliaction_Start' an, und wir planen, nach azur zu gehen, aber in azurblauen' SqlDependency' wird nicht unterstützt, also bekommen wir [diese] (http://stackoverflow.com/ Fragen/33693020/azure-sql-server-Fehler-Anweisung-receive-msg-ist-nicht-unterstützt-in-dieser-Version) Fehler geplant für [Auslöser] (http://stackoverflow.com/questions/ 9880091/monitor-data-changes-in-sql-azure) um Datenbankänderungen mit signaR zu verfolgen, irgendwelche besseren Vorschläge? – stom
Persönlich bin ich kein großer Fan von entweder SqlDependency noch Trigger Ansätze. Stattdessen würde ich in Erwägung ziehen, Nachrichten an einen Service Bus (oder eine Warteschlange in irgendeiner Form) zu veröffentlichen. Ein Listener kann die Daten in der Datenbank persistieren (wie Sie jetzt sicher sind), während ein anderer Listener Ihre SignalR Push-Benachrichtigungen verarbeiten kann. Es löst nicht nur dieses Problem, sondern bietet Ihnen auch eine Widerstandsfähigkeit gegen Serviceausfälle. Das ist, wie ich es annähme, aber ich verstehe, dass Ihre SqlDependency-Probleme nicht direkt aufgelöst werden, sorry. – Smudge202