vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Mails senden, abrufen und decodieren - ganz easy ;-)  
 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

VB & Datenbanken
Recordset per Set an anderes Recordset übertragen 
Autor: xero1988
Datum: 06.07.11 10:48

Hallo liebe Community!

Ich habe ein Problem, an dem ich mir echt die Haare ausreißen könnte.
Ich mache eine Datenbankabfrage (MSSQL, ADODB) und möchte hinterher bestimmte Einträge aus dem Recordset entfernen. Hierzu erstelle ich ein temporäres Recordset mit exakt den gleichen Spalten und Werten, wie das aus der Datenbank. Ich durchlaufe das temporäre Recordset und entferne dort die Einträge, die nicht benötigt werden. Anschließend möchte ich das temporäre Recordset mit dem SET-Befehl an das ursprüngliche Recordset übergeben. Ich würde diesen Filter ja bereits in der SQL-Abfrage einbauen, dies ist leider nicht möglich, da das Programm sehr komplex ist und ich erstmal alle Einträge brauche.

Hier der Code:

' Recordset bereinigen und übergeben
Set tstyle(aktStyle).rs = CheckPersonal(tstyle(aktStyle).rs)
Und hier die Funktion:
Private Function CheckPersonal(ByRef rs As ADODB.Recordset) As ADODB.Recordset
    Dim nAdressNr As Long
    Dim Pers As New ADODB.Recordset
    Dim tmpRs As New ADODB.Recordset
    Dim i%
 
    rs.MoveFirst
    For i = 0 To rs.Fields.count - 1
        tmpRs.Fields.Append rs.Fields(i).Name, rs.Fields(i).Type, rs.Fields( _
          i).DefinedSize, rs.Fields(i).Attributes
    Next i
 
    tmpRs.Open
 
    rs.MoveFirst
    Do While Not rs.EOF
        tmpRs.AddNew
        For i = 0 To rs.Fields.count - 1
            tmpRs.Fields(i).Value = rs.Fields(i).Value
        Next i
        rs.MoveNext
    Loop
 
    tmpRs.MoveFirst
    Do While Not tmpRs.EOF
        nAdressNr = Val(tmpRs!AdressNr)
        If Pers.State = adStateOpen Then Pers.Close
        Pers.Open "SELECT p.Abteilung FROM Personalstamm as p INNER JOIN" & _
          "Marketingstamm AS m ON p.AdressID = m.AdressID WHERE m.AdressNr = " _
          & nAdressNr, conn
        If Not Pers.EOF Then
            If Not (RechtFuerAbteilung(Trim(Pers!Abteilung))) Then
                tmpRs.Delete adAffectCurrent
            End If
        End If
        tmpRs.MoveNext
    Loop
 
    tmpRs.MoveFirst
    rs.MoveFirst
 
    Set CheckPersonal = tmpRs
End Function
Leider hat sich in tstyle(aktStyle).rs nichts verändert, im tmpRs allerdings schon.
Ich hoffe, jemand kann mir helfen! Vielen Dank schonmal!!!

Beitrag wurde zuletzt am 06.07.11 um 10:54:39 editiert.
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Recordset per Set an anderes Recordset übertragen2.571xero198806.07.11 10:48
Re: Recordset per Set an anderes Recordset übertragen1.343Dirk06.07.11 12:51
Re: Recordset per Set an anderes Recordset übertragen1.301xero198806.07.11 12:54
Re: Recordset per Set an anderes Recordset übertragen1.185Dirk06.07.11 13:08
Re: Recordset per Set an anderes Recordset übertragen1.158xero198806.07.11 13:15
Re: Recordset per Set an anderes Recordset übertragen1.168Dirk06.07.11 13:59
Re: Recordset per Set an anderes Recordset übertragen1.159wb-soft06.07.11 13:34
Re: Recordset per Set an anderes Recordset übertragen1.145xero198806.07.11 13:45
Re: Recordset per Set an anderes Recordset übertragen1.097xero198806.07.11 14:13
Re: Recordset per Set an anderes Recordset übertragen1.135Dirk06.07.11 14:33
Re: Recordset per Set an anderes Recordset übertragen1.103wb-soft06.07.11 14:17
Re: Recordset per Set an anderes Recordset übertragen1.221xero198806.07.11 14:39
Re: Recordset per Set an anderes Recordset übertragen1.175Dirk06.07.11 14:59
Re: Recordset per Set an anderes Recordset übertragen1.138xero198806.07.11 15:30
Re: Recordset per Set an anderes Recordset übertragen1.182Dirk06.07.11 15:43
Re: Recordset per Set an anderes Recordset übertragen1.152xero198806.07.11 17:32
Re: Recordset per Set an anderes Recordset übertragen1.175Franki07.07.11 02:09

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