vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
vb@rchiv Offline-Reader - exklusiv auf der vb@rchiv CD Vol.4  
 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.NET - Ein- und Umsteiger
Re: string soll im code eingefügt werden 
Autor: ModeratorDaveS (Moderator)
Datum: 21.01.06 19:25

Hier ist ein komplettes Beispiel
 
 
    Public Function CreateAssemblyFromCode(ByVal Code As String) As [Assembly]
        Dim CDP As CodeDomProvider = New Microsoft.VisualBasic.VBCodeProvider        
        Dim Compiler As ICodeCompiler = CDP.CreateCompiler()
        Dim CP As New CompilerParameters(New String() {"System.Data.Dll"})
        CP.GenerateInMemory = True
        Dim CR As CompilerResults = Compiler.CompileAssemblyFromSource(CP, Code)
        If CR.Errors.Count <> 0 Then
            For Each ce As System.CodeDom.Compiler.CompilerError In CR.Errors
                Debug.WriteLine(ce.ErrorText)
            Next
            Return Nothing
        Else
            Return CR.CompiledAssembly
        End If
    End Function
 
    Private obj As Object
    Private method As MethodInfo
 
    Private Sub CompileMethod(ByVal str As String)
        Dim Code As String = _
            "Imports System.Data.OleDb " & vbCrLf & _
            "Namespace test " & vbCrLf & _
              "Public Class GetData " & vbCrLf & _
                "Public Function GetData(ByVal dr As OleDbDataReader) As String" & _
                "" & vbCrLf & _
                  "Return " & str & vbCrLf & _
                "End Function " & vbCrLf & _
              "End Class " & vbCrLf & _
            "End Namespace"
        'Debug.WriteLine(Code)
 
        Dim asm As [Assembly] = CreateAssemblyFromCode(Code)
        obj = asm.CreateInstance("test.GetData")
        method = obj.GetType().GetMethod("GetData")
    End Sub
 
    Public Sub trx()
        Dim str As String = "dr(""ShipName"").SubString(0,7)"
        Dim sql1 As String = "SELECT * from Orders"
        Dim conn As New OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0; Data" & _
          "Source=nwind.mdb;")
        Dim cmd As New OleDbCommand(sql1, conn)
        Try
            CompileMethod(str)
            cmd.Connection.Open()
            Dim dbDR As OleDb.OleDbDataReader = cmd.ExecuteReader()
            While dbDR.Read()
                Dim val As String = CType(method.Invoke(obj, New Object() _
                  {dbDR}), String)
                MsgBox(val)
            End While
        Catch ex As Exception
            MsgBox(ex.ToString())
        Finally
            cmd.Connection.Close()
        End Try
    End Sub
Der String

dr("ShipName").SubString(0,7)

wird dynamisch ausgewertet für jeden Satz vom DataReader.

________
Alle Angaben ohne Gewähr. Keine Haftung für Vorschläge, Tipps oder sonstige Hilfe, falls es schiefgeht, nur Zeit verschwendet oder man sonst nicht zufrieden ist

alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
string soll im code eingefügt werden1.717GuidoH21.01.06 11:02
Bitte nochmal neu1.357Drapondur21.01.06 12:33
Re: Bitte nochmal neu1.290Urot21.01.06 13:04
Re: Bitte nochmal neu1.353GuidoH21.01.06 13:05
mehr Code, bitte1.258Drapondur21.01.06 13:15
Re: mehr Code, bitte1.251GuidoH21.01.06 13:42
Re: mehr Code, bitte1.212Urot21.01.06 14:06
Re: string soll im code eingefügt werden1.360GuidoH21.01.06 14:40
Re: string soll im code eingefügt werden1.223vbtest221.01.06 17:31
Re: string soll im code eingefügt werden1.258GuidoH21.01.06 17:46
Re: string soll im code eingefügt werden1.254ModeratorDaveS21.01.06 18:03
Re: string soll im code eingefügt werden1.249GuidoH21.01.06 18:51
Re: string soll im code eingefügt werden1.250ModeratorDaveS21.01.06 18:55
Re: string soll im code eingefügt werden1.279GuidoH21.01.06 20:07
Re: string soll im code eingefügt werden1.317GuidoH22.01.06 15:03
Re: string soll im code eingefügt werden1.211ModeratorDaveS22.01.06 17:19
Re: string soll im code eingefügt werden1.223GuidoH22.01.06 23:30
Re: string soll im code eingefügt werden1.263ModeratorDaveS23.01.06 10:29
Re: string soll im code eingefügt werden1.237GuidoH23.01.06 22:56
Re: string soll im code eingefügt werden1.961ModeratorDaveS21.01.06 19:25
Re: string soll im code eingefügt werden1.252GuidoH21.01.06 20:27

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