vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Top-Preis! AP-Access-Tools-CD Volume 1  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

ADO.NET / Datenbanken
SqlDependency / MsSql 2005: dependency.OnChange wird permanent gefeuert 
Autor: riggson
Datum: 19.11.08 13:24

Hi zusammen,

für meine derzeitige Programmierung wäre es hilfreich über bestimmte Änderungen an einer Datenbanktabell im SQL-Server informiert zu werden. Deswegen habe ich mich mal an SqlDependency gewagt. Nur leider funktioniert es mit meiner Datenbank nicht wie zu erwarten.

Ich habe ein kleines, funktionierendes Beispiel im Netz gefunden:

Imports System.ComponentModel
Imports System.Data.SqlClient
 
Public Class Form1
 
    Private Const connectionString As String = "server=127.0.0.1;" & _
      "database=AdventureWorks; trusted_connection=true"
 
 
    Private Sub Form1_Load(ByVal sender As Object, ByVal e As System.EventArgs) _
      Handles Me.Load
        SqlClient.SqlDependency.Start(connectionString)
 
        getData()
 
    End Sub
 
    Private Sub getData()
        Using connection As New SqlConnection(connectionString)
            connection.Open()
            Using command As New SqlCommand("select EmailAddress from" & _
              "Person.Contact where  ContactID = 1", connection)
                Dim dependency As New SqlClient.SqlDependency(command)
                AddHandler dependency.OnChange, AddressOf dependency_onchange
 
                TextBox1.Text = CType(command.ExecuteScalar(), String)
            End Using
        End Using
    End Sub
 
    Private Sub dependency_onchange(ByVal sender As Object, ByVal e As _
      SqlNotificationEventArgs)
        If CType(Me, ISynchronizeInvoke).InvokeRequired Then
            Dim d As New OnChangeEventHandler(AddressOf dependency_onchange)
            CType(Me, ISynchronizeInvoke).BeginInvoke(d, New Object() {sender, _
              e})
 
 
        End If
 
        Dim dependency As SqlClient.SqlDependency = CType(sender, _
          SqlClient.SqlDependency)
 
        RemoveHandler dependency.OnChange, AddressOf dependency_onchange
 
        getData()
 
    End Sub
End Class
Dies funktioniert auf Anhieb korrekt mit der Tabelle AdventureWorks, die ich zu Testzwecken installiert habe. Wenn ich in diesem Beispiel im Connection-String die Datenbank durch meine ersetze und dann die Abfrage auf ein Feld in meiner Tabelle anpasse, dann wird sofort das onChange-Event der SqlDependency ausgelöst. Das endet dann in einer Endlosschleife.

Den Broker habe ich auf beiden Datenbanken aktiviert.

SELECT is_broker_enabled FROM sys.databases WHERE name = 'MeineDatenbank'
Ergibt ebenfalls 1.

Ebenso habe ich mir die Eigenschaften der Datenbanken angesehen und mal komplett alles im Bereich "ALTER TABLE ...." auf meine Datenbank übertragen, um zu sehen ob es eine Einstellung ist. Ebenfalls ohne Erfolg. Hier die Einstellungen meiner Datenbank:

Hat jemand einen Tipp für mich? Bin echt ratlos...
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
SqlDependency / MsSql 2005: dependency.OnChange wird permane...2.927riggson19.11.08 13:24
Re: SqlDependency / MsSql 2005: dependency.OnChange wird per...1.242riggson19.11.08 13:25
Re: SqlDependency / MsSql 2005: dependency.OnChange wird per...1.231riggson19.11.08 14:21

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel