Zum Inhalt springen

VB.NET/ASP2.0 XmlWriter


stonetherippa

Empfohlene Beiträge

Hallo ich habe mit Xml Writer eine Xml erstellt und möchte mit einer FOR EACH

die datenbank auslesen und in die XMl file reinschreiben,kann mir jenmand helfen?Stehe auf dem schlauch:-(..

hier ein Ausschnitt vom momentanen Code:

 

 Dim dRo As DataRow

      For Each dRo In ds.Tables("Daten").Rows

     'und hier bin  ich schon am Ende...


       Next


Using writer As XmlWriter = XmlWriter.Create("C:\xxx.xml",wset)

        writer.WriteStartDocument

        writer.WriteStartElement("Personen")

        writer.WriteStartElement("Person")

        writer.WriteStartAttribute("Nachname")

        writer.WriteValue(varNachname)

        writer.WriteEndAttribute()

        writer.WriteStartAttribute("Name")

        writer.WriteValue(name)

        writer.WriteEndAttribute()

        writer.WriteStartAttribute("Alter")

        writer.WriteValue(varAlter)

        writer.WriteEndAttribute()

        writer.WriteEndElement()

        writer.WriteEndElement()

        writer.WriteEndDocument()

Wie schaffe ich es hier die Xml dynamisch zu füllen?

zb dass bei

writer.WriteValue(name) aus der Db(wie oben in der FOREACH(Betriebe) die Namen ausgelesen werden(natürlich nicht alle in einem String)

?jemand einen VorschlaG?

Link zu diesem Kommentar
Auf anderen Seiten teilen

Kommt drauf an ob du ein typisiertes oder untypisiertes Dataset hast. Woran hapert es denn? Beim schreiben der Xml oder beim Zugriff auf die Felder? Wie soll das xml denn aussehen? Mit den Werten als Attributen oder jeder Wert ein Element? Willst du XmlDocument oder XmlWriter verwenden?

Wenn es dir nur um das for each geht dann so:

for each (DataRow singleRow in myDs.Tables[0] )

{

string name = singleRow["Name]";

// Name in Xml schreiben...

}

Link zu diesem Kommentar
Auf anderen Seiten teilen

Es erstellt mir die XML wie ich sie will, nur,will ich hier an den Stellen, wo die Variablen Name, Alter, Nachname stehen, die Ergebnisse der Db einfügen, hier der gesamte Code:


 Dim vstr = ConfigurationManager.ConnectionStrings("new_Cs").ConnectionString

     Dim con As New SqlConnection(vstr)

     'SQL Query

     Dim sql_name As String = "SELECT name,nachname,alter FROM Personen WHERE Personen.name IS NOT NULL"


     Dim data As New SqlDataAdapter(sql_name,con)

     Dim ds As DataSet = New DataSet()

     data.Fill(ds, "Personen")

     Dim varName As String = "stName"   

     Dim varNachname As String = "stNachname"

     Dim varAlta As Integer = 66

     Dim wset As New XmlWriterSettings()

     wset.Indent = True

     wset.NewLineOnAttributes = True 



     try

     Using writer As XmlWriter = XmlWriter.Create("C:\xxx.xml",wset)


        writer.WriteStartDocument

        writer.WriteStartElement("Personen")

        writer.WriteStartElement("Person")

        writer.WriteStartAttribute("Nachname")

        writer.WriteValue(varNachname)   'Hier den Nachnamen aus der Db

        writer.WriteEndAttribute()

        writer.WriteStartAttribute("Name")

        writer.WriteValue(name)   'Hier den Namen aus der Db

        writer.WriteEndAttribute()     

        writer.WriteStartAttribute("Alta")  

        writer.WriteValue(varAlta)    'Hier das Alter aus der Db

        writer.WriteEndAttribute()

        writer.WriteEndElement()

        writer.WriteEndElement()

        writer.WriteEndDocument()

        writer.Flush()

        lbl2.Text = "XML-Datei erfolgreich erstellt"

     End Using 

     catch ex As Exception

     lbl2.Text = "EEERRROOORR!!!" & ex.Message 

     End Try

End Sub

ThX

Link zu diesem Kommentar
Auf anderen Seiten teilen

genau sowas,danke:-)wie schaffe ich es jetzt dass er mir die Namen nicht alle Hintereinander sondern alle einzeln reinschreibt?

im Moment:

<Personen>

<Person Nachname="Lustig" Name="Thomas Dieter Franz Ullrich Lars" Alter="22"/>

</Personen>

und wie mache ich es dass es so wird:

<Personen>

<Person Nachname="Lustig" Name="Thomas" Alter="44"/>

<Person Nachname="Frech" Name="Dieter" Alter="44"/>

</Personen>

gaub ich check es nicht....:old

Link zu diesem Kommentar
Auf anderen Seiten teilen

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...