Formular mit bestimmten Datensatz öffnen
Hallo zusammen,
ich fürchte, die Sache ist komplizierter als der Titel verspricht.
Ich habe eine Tabelle mit vielen Feldern.
Aus Gründen der Übersichtlichkeit stelle ich in einem Formular nur wenige Felder dar.
Nun möchte ich andere Felder derselben Tabelle und desselben Datensatzes in einem neuen Formular öffnen.
Dazu habe ich folgende Routine erstellt:
Private Sub OpenTS_Click()
Me.Refresh
Dim RecSet As Integer
RecSet = Me.ID
DoCmd.OpenForm "Therapiesitzungen"
DoCmd.GoToRecord , , acGoTo, RecSet
End Sub
Das hat anfänglich auch super funktioniert.
Er hat mir, wenn ich im Datensatz mit der ID 5 war auch im neuen Formular die Inhalte des Satzes mit der ID 5 gezeigt.
Dann habe ich z. B. den Satz mit der ID 2 gelöscht. Wie gesagt: Alles in einer Tabelle.
Danach hat er mir, wenn ich in ID 5 war, das neue Formular mit ID 6 geöffnet.
Ich habe Haltepunkte gesetzt. Auch da hatte die Variable RecSet immer den richtigen Wert (in diesem Fall ID 5).
Dann habe ich noch einen Datensatz gelöscht. Daraufhin öffnete er mir im neuen Formular die ID 7
Also erst ID x + 1, dann ID x +2 u.s.w. je nachdem wie viele Datesätze ich gelöscht habe.
Hier im Forum oder bei Google oder bei F1 habe ich nicht annähernd eine Lösung gefunden.
Und ich suche schon lange...
Hilfe!
Vielen Dank im vorraus
Rasi
ich fürchte, die Sache ist komplizierter als der Titel verspricht.
Ich habe eine Tabelle mit vielen Feldern.
Aus Gründen der Übersichtlichkeit stelle ich in einem Formular nur wenige Felder dar.
Nun möchte ich andere Felder derselben Tabelle und desselben Datensatzes in einem neuen Formular öffnen.
Dazu habe ich folgende Routine erstellt:
Private Sub OpenTS_Click()
Me.Refresh
Dim RecSet As Integer
RecSet = Me.ID
DoCmd.OpenForm "Therapiesitzungen"
DoCmd.GoToRecord , , acGoTo, RecSet
End Sub
Das hat anfänglich auch super funktioniert.
Er hat mir, wenn ich im Datensatz mit der ID 5 war auch im neuen Formular die Inhalte des Satzes mit der ID 5 gezeigt.
Dann habe ich z. B. den Satz mit der ID 2 gelöscht. Wie gesagt: Alles in einer Tabelle.
Danach hat er mir, wenn ich in ID 5 war, das neue Formular mit ID 6 geöffnet.
Ich habe Haltepunkte gesetzt. Auch da hatte die Variable RecSet immer den richtigen Wert (in diesem Fall ID 5).
Dann habe ich noch einen Datensatz gelöscht. Daraufhin öffnete er mir im neuen Formular die ID 7
Also erst ID x + 1, dann ID x +2 u.s.w. je nachdem wie viele Datesätze ich gelöscht habe.
Hier im Forum oder bei Google oder bei F1 habe ich nicht annähernd eine Lösung gefunden.
Und ich suche schon lange...
Hilfe!
Vielen Dank im vorraus
Rasi
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 162169
Url: https://administrator.de/contentid/162169
Ausgedruckt am: 22.11.2024 um 20:11 Uhr
4 Kommentare
Neuester Kommentar
DoCmd.GoToRecord hat das Problem, daß Du nur einen Offset angibst, also wieviele Datensätze man vor oder zurückgeht. Ist also eigentlich nur gut um zum nächsten zu springen.
Man kann damit keinen bestimmten auswählen.
Du kannst Dem zu öffnenden Formular aber einen Filter mitgeben:
Falls im neuen Form das Feld nicht ID heißt bitte [ID] entsprechend anpassen.
Und je nach Datentyp muß der Vergleich noch angepasst werden, bei einem String z.B. einfache Anführungszeichen etc.
Man kann damit keinen bestimmten auswählen.
Du kannst Dem zu öffnenden Formular aber einen Filter mitgeben:
DoCmd.OpenForm "Therapiesitzungen",,,"[ID]=" & Me.ID
Und je nach Datentyp muß der Vergleich noch angepasst werden, bei einem String z.B. einfache Anführungszeichen etc.