Avatar billede flashit Nybegynder
04. marts 2009 - 15:29 Der er 2 kommentarer og
1 løsning

Linq to xml

Hej e.

Er her en som kan hjælpe med noget LInq to xml

Jeg har dette xml (kun en lille del)

<?xml version="1.0" encoding="utf-8"?>
<edmx:Edmx Version="1.0" xmlns:edmx="http://schemas.microsoft.com/ado/2007/06/edmx">
  <!-- EF Runtime content -->
  <edmx:Runtime>
    <!-- SSDL content -->
    <edmx:StorageModels>
      <Schema Namespace="EFModel.Store" Alias="Self" Provider="System.Data.SqlClient" ProviderManifestToken="2005" xmlns:store="http://schemas.microsoft.com/ado/2007/12/edm/EntityStoreSchemaGenerator" xmlns="http://schemas.microsoft.com/ado/2006/04/edm/ssdl">
        <EntityContainer Name="EFModelStoreContainer">
          <EntitySet Name="Orders" EntityType="EFModel.Store.Orders" store:Type="Tables" Schema="dbo" />
          <EntitySet Name="sysdiagrams" EntityType="EFModel.Store.sysdiagrams" store:Type="Tables" Schema="dbo" />
          <EntitySet Name="Users" EntityType="EFModel.Store.Users" store:Type="Tables" Schema="dbo" />
          <AssociationSet Name="FK_Orders_Users" Association="EFModel.Store.FK_Orders_Users">
            <End Role="Users" EntitySet="Users" />
            <End Role="Orders" EntitySet="Orders" />
          </AssociationSet>
        </EntityContainer>
        <EntityType Name="Orders">
          <Key>
            <PropertyRef Name="OrderID" />
          </Key>
          <Property Name="OrderID" Type="int" Nullable="false" StoreGeneratedPattern="Identity" />
          <Property Name="UserID" Type="int" Nullable="false" />
          <Property Name="OrderName" Type="ntext" Nullable="false" />
        </EntityType>

...........

Jeg vil gerne have fat i følgende:

Orders
    Name ="OrderID" type="int"
Name ="UserID" type="int"
Name ="OrderName" type="ntext"

Men hvordan kan jeg komme til denne node <EntityType Name="Orders"> når jeg ikke kender dens navn?

Jeg vil bare gerne havde den til at loope alle noder at typen EntityType og give mig dens navn samt dens indhold som vist.

Håber det giver mening.
Avatar billede arne_v Ekspert
05. marts 2009 - 03:51 #1
Din beskrivelse af problemet er ikke helt klar.

Men et skud fra hoften:

            XDocument doc = XDocument.Load(@"C:\foobar.xml");
            foreach(XElement ot in doc.Descendants("{http://schemas.microsoft.com/ado/2006/04/edm/ssdl}EntityType"))
            {
                Console.WriteLine(ot.Attribute("Name").Value + ":");
                foreach(XElement p in ot.Descendants("{http://schemas.microsoft.com/ado/2006/04/edm/ssdl}Property"))
                {
                    Console.WriteLine(p.Attribute("Name").Value + " " + p.Attribute("Type").Value);
                }
            }
Avatar billede flashit Nybegynder
08. marts 2011 - 16:28 #2
Tak for hjælpen. Lægger du ikke et svar så du kan få points.
Avatar billede arne_v Ekspert
08. marts 2011 - 16:42 #3
ok
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
IT-kurser om Microsoft 365, sikkerhed, personlig vækst, udvikling, digital markedsføring, grafisk design, SAP og forretningsanalyse.

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester