Gå til innhold

Anbefalte innlegg

Hei,

 

Jeg holder på med en solution i VS der jeg har to prosjekter. Den ene er et vanlig windows form der jeg fyller et DataSet med data fra en XML-fil. I dette DS'et har jeg laget tabeller og relations så xml-fila inneholder kun data.

 

Det andre prosjektet skal være en ASP.net nettside der jeg også er avhengig av å bruke et DS som fylles fra samme XML-fil. Jeg lurer derfor på:

  1. Er det noen god måte å fylle disse DS'ene fra samme XML-fil? Når det skrives en endring til XML-fila så vil jeg jo ha denne opp i det andre prosjektet og til det så kan jeg ikke se noen annen løsningen enn å bruke en absolutt sti av typen @"D:\mappe\...". Hva annet kan jeg bruke?
  2. Det å fylle Win-Form DS'et fra en xml fil som ligger i samme prosjekt går helt fint. For å få over tabellstrukturen fra Win-Form så laget jeg et DS med samme navn og overskrev filene i ASP.net med de fra Win-form. Når jeg bruker følgende kode i ASP.net-prosjektet med denne koden her
     
    		DataSet1 ds = new DataSet1();
    		ds.ReadXml(Server.MapPath("~/DataSetXML.xml"), XmlReadMode.IgnoreSchema);
    		DataTable dtGjest = ds.Tables["Gjest"];
    		string select = "Epost='" + LoginUser.UserName.ToString() + "'";
    					//System.Diagnostics.Debug.WriteLine(ds.Tables["Gjest"].Rows.Count.ToString());
    	    DataRow[] dr = dtGjest.Select(select);
    


     
    så får jeg bare opp en "NullReferenceException" på linja som er nederst i koden. Dette må jo bety at DS'et faktisk ikke har tabellen jeg ønsker å hente data fra? Eller er jeg helt på jordet nå?

 

All hjelp mottas med stor takk!

Endret av NorwegianSF
Lenke til kommentar
Videoannonse
Annonse

Jeg bruker jo samme måten å initiere DataRow på ellers i koden og det fungerer fint. Jeg gjorde en test i går der jeg prøvde å hente ut antall tabeller og da fikk jeg samme exception så jeg begynner å tro at problemet kanskje er at jeg må lage DataSet'et fra bunnen av.

 

Når jeg initierer en DR så gjør jeg følgende dersom jeg skal hente info om en gitt gjest:

DataRow[] gjesteInfo = dtGjester.Select("GjesteNr='" + rad["GjesteNr"] + "'");

Endret av NorwegianSF
Lenke til kommentar

Fant det som var problemet for min del, nemlig at jeg der jeg leser fra XML så har jeg følgende kode:

ds.ReadXml(Server.MapPath("~/DataSetXML.xml"), XmlReadMode.IgnoreSchema);

 

men i Win-form så har jeg ikke med "XmlReadMode.IgnoreSchema". Jeg tok bort dette så koden da blir

 

ds.ReadXml(Server.MapPath("~/DataSetXML.xml"));

 

og da forsvant problemet :)

Lenke til kommentar

Opprett en konto eller logg inn for å kommentere

Du må være et medlem for å kunne skrive en kommentar

Opprett konto

Det er enkelt å melde seg inn for å starte en ny konto!

Start en konto

Logg inn

Har du allerede en konto? Logg inn her.

Logg inn nå
  • Hvem er aktive   0 medlemmer

    • Ingen innloggede medlemmer aktive
×
×
  • Opprett ny...