Bonjour,
je résume mon problème: je veut afficher un TreeView dans une page ASP qui affiche en premier niveau tous les département à partir d'une base de données SQL et les dossiers contenus dans chaque département dans les niveau les plus bas (chaque dossier peut contenir un nombre quelconque de dossier), pour le faire j'ai développé le code suivant:
Departement.cs
Code:
public class Departement
{
public virtual Guid id_dept { get; set; }
public virtual String nom_dept { get; set; }
public virtual IList<Dossier> Dossiers { get; set; }
public virtual IList<Role> Roles { get; set; }
}
Deprtement.hbm.xml
Code:
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
assembly="GED" namespace="GED.Beans">
<class name="Departement">
<!-- identifier -->
<id name="id_dept">
<generator class="guid" />
</id>
<property name="nom_dept" />
<bag name="Dossiers" inverse="true" lazy="false" cascade="all" table="Dossier">
<key column="dept" foreign-key="FK_Dossier_Departement"/>
<one-to-many class="Dossier"/>
</bag>
</bag>
</class>
</hibernate-mapping>
Dossier.cs
Code:
public class Dossier
{
public virtual Guid id_dossier { get; set; }
public virtual String nom_dossier { get; set; }
//clés étrangères
public virtual Departement dept { get; set; }
public virtual Dossier parent { get; set; }
public virtual IList<Dossier> fils { get; set; }
}
Dossier.hbm.xml
Code:
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
assembly="GED" namespace="GED.Beans">
<class name="Dossier">
<!-- identifier -->
<id name="id_dossier">
<generator class="guid" />
</id>
<property name="nom_dossier" />
<property name="date_creation_dossier" />
<property name="date_maj_dossier" />
<many-to-one name="dept" class="Departement" cascade="all"/>
<many-to-one name="parent" class="Dossier" cascade="all"/>
<bag name="fils" inverse="true" lazy="false" cascade="all" table="Dossier">
<key column="parent" foreign-key="FK_Dossier_Dossier"/>
<one-to-many class="Dossier"/>
</bag>
</class>
</hibernate-mapping>
Code pour remplir le TreeView:
Code:
public void PopulateTree(Dossier ds, TreeNode node)
{
foreach (Dossier df in ds.fils)
{
TreeNode d = new TreeNode(df.nom_dossier.ToString());
d.PopulateOnDemand = true;
d.SelectAction = TreeNodeSelectAction.Expand;
node.ChildNodes.Add(d);
PopulateTree(df, d);
}
}
protected void TreeView1_TreeNodePopulate(object sender, TreeNodeEventArgs e)
{
foreach (Departement dept in DepartementRepository.GetAll())
{
TreeNode t = new TreeNode(dept.nom_dept.ToString());
t.PopulateOnDemand = true;
t.SelectAction = TreeNodeSelectAction.Expand;
e.Node.ChildNodes.Add(t);
foreach (Dossier ds in dept.Dossiers)
{
TreeNode d = new TreeNode(ds.nom_dossier.ToString());
d.PopulateOnDemand = true;
d.SelectAction = TreeNodeSelectAction.Expand;
e.Node.ChildNodes.Add(d);
}
}
}
lorsque j'affiche la page asp sur le navigateur il lance l'exception suivante (après un temps d'attente très long):
WebDev.WebService.exe a rencontré un problème et doit fermer...
quelqu'un entre vous peut m'aider à résoudre ce problème
merci