vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
NEU! sevCoolbar 3.0 - Professionelle Toolbars im modernen Design!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2025
 
zurück

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

Fortgeschrittene Programmierung
Re: Import-Tool für Textdateien 
Autor: whisky1108
Datum: 08.03.16 11:37

Anbei der Abfrage Generator für den Daten Import (Warnung! Mein Programmierstil ist nicht der beste!.. learning by doing) Teil 1

Public Sub subDBDataImport()
 
Dim sSQL As String
Dim sSQLUpdFields As String
Dim sSQLSearchFields As String
Dim sSQLDBFields As String
Dim sFilt() As String
Dim sAnfügeFeld() As String
Dim sSuchKriterium() As String
Dim sSQLOrderBy As String
Dim sFilter As String
Dim bUpd As Boolean
Dim rs As New ADODB.Recordset
 
On Error GoTo Err_Handl
 
 
frmDIR_STAM_Import.MousePointer = vbHourglass
 
With frmDIR_STAM_Import.grd_dbf
    'ermitteln welche spalten angefügt werden müssen
    For i = 1 To .Rows
        If .ListItems(i).CellText(2) <> "" Then
            sSQLUpdFields = sSQLUpdFields & i & IIf(i < .Rows, vbCrLf, "")
        End If
    Next i
 
    For i = 1 To .Rows
        If .ListItems(i).CellText(2) <> "" Then
             sSQLDBFields = sSQLDBFields & .ListItems(i).CellText(2) & IIf(i < _
               .Rows, vbCrLf, "")
        End If
    Next i
    'spalten zeilenweise auslesen
    Erase sFilt
    sFilt = Split(sSQLUpdFields, vbCrLf, , vbTextCompare)
    sSQLUpdFields = vbNullString
    sAnfügeFeld = Split(sSQLDBFields, vbCrLf, , vbTextCompare)
    sSQLDBFields = vbNullString
 
 
Dim xIndex As Integer
xIndex = vbEmpty
For i = 1 To frmDIR_STAM_Import.grd_srch.Rows
    If i <= .Rows Then
        If .ListItems(i).CellText(1) <> vbNullString Then
        xIndex = xIndex + 1
        End If
    End If
 
    If frmDIR_STAM_Import.grd_srch.ListItems(i).CellText(2) <> "" And _
      frmDIR_STAM_Import.grd_srch.ListItems(i).CellText(3) <> "" Then
    sSQLSearchFields = sSQLSearchFields & IIf(sSQLSearchFields <> _
    vbNullString, vbCrLf, "") & xIndex & ";" & _
    frmDIR_STAM_Import.grd_srch.ListItems(i).CellText(2)
    End If
Next i
End With
 
sSuchKriterium = Split(sSQLSearchFields, vbCrLf, , vbTextCompare)
sSQLSearchFields = vbNullString
 
    'Datenbankfelder ermitteln
    For i = LBound(sAnfügeFeld) To UBound(sAnfügeFeld)
    sSQLDBFields = sSQLDBFields & RTrim(sAnfügeFeld(i)) & ","
    Next i
 
    'letztes satzzeichen entfernen
    sSQLDBFields = fnClearDelimeter(sSQLDBFields, ",")
    If (Not Not sSuchKriterium) <> 0 Then
    sSQL = "UPDATE " & frmDIR_STAM_Import.sDB & " SET "
    Else
    sSQL = "INSERT IGNORE INTO " & frmDIR_STAM_Import.sDB & " (" & sSQLDBFields _
      & ") VALUES ("
    End If
    sSQLDBFields = vbNullString
 
    'Order BY
    sSQLOrderBy = vbNullString
    For i = 1 To frmDIR_STAM_Import.grd_srch.Rows
    If frmDIR_STAM_Import.grd_srch.Text(i, 4) <> vbNullString Then _
      sSQLOrderBy = sSQLOrderBy & frmDIR_STAM_Import.grd_srch.Text(i, 2) & " " _
      & frmDIR_STAM_Import.grd_srch.Text(i, 4) & ","
    Next i
    'letztes satzzeichen entfernen
    If sSQLOrderBy <> vbNullString Then sSQLOrderBy = "ORDER BY " & _
      fnClearDelimeter(sSQLOrderBy, ",")
 
'werte aus der imp anhand des gestzten filters ermitteln
For a = 1 To frmDIR_STAM_Import.grd_imp.Rows
    If (Not Not sSuchKriterium) <> 0 Then
            'QuelldateiFelder ermitteln
            For i = LBound(sFilt) To UBound(sFilt)
                If frmDIR_STAM_Import.grd_imp.Text(a, CInt(sFilt(i))) <> _
                  vbNullString Then _
                sSQLUpdFields = sSQLUpdFields & RTrim(sAnfügeFeld(i)) & "='" & _
                frmDIR_STAM_Import.grd_imp.Text(a, CInt(sFilt(i))) & "',"
            Next i
            'letztes satzzeichen entfernen
            sSQLUpdFields = fnClearDelimeter(sSQLUpdFields, ",")
 
            If sSQLUpdFields = vbNullString Then GoTo NextLine
    Else
            'QuelldateiFelder ermitteln
            For i = LBound(sFilt) To UBound(sFilt)
            sSQLUpdFields = sSQLUpdFields & "'" & _
              frmDIR_STAM_Import.grd_imp.Text(a, CInt(sFilt(i))) & "',"
            Next i
            'letztes satzzeichen entfernen
            sSQLUpdFields = fnClearDelimeter(sSQLUpdFields, ",")
 
            If sSQLUpdFields = vbNullString Then GoTo NextLine
            'Quelldaten anfügen
            sSQLUpdFields = sSQLUpdFields & ")"
    End If
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Import-Tool für Textdateien1.835hanjo1202.03.16 14:22
Re: Import-Tool für Textdateien1.132Franki03.03.16 01:10
Re: Import-Tool für Textdateien1.073Manfred X03.03.16 11:12
Re: Import-Tool für Textdateien1.059Franki04.03.16 01:16
Re: Import-Tool für Textdateien1.290hanjo1204.03.16 17:27
Re: Import-Tool für Textdateien1.119Franki05.03.16 05:39
Re: Import-Tool für Textdateien1.240whisky110808.03.16 10:39
Re: Import-Tool für Textdateien1.057whisky110808.03.16 10:41
Re: Import-Tool für Textdateien1.101whisky110808.03.16 10:42
Re: Import-Tool für Textdateien1.015whisky110808.03.16 11:34
Re: Import-Tool für Textdateien1.172whisky110808.03.16 11:34
Re: Import-Tool für Textdateien1.019whisky110808.03.16 11:48
Re: Import-Tool für Textdateien1.042whisky110808.03.16 11:37
Re: Import-Tool für Textdateien1.057whisky110808.03.16 11:38

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-2025 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