EntrepotActionEducative.cs 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Text;
  4. using System.Data;
  5. using System.Data.SqlClient;
  6. using CG67.FicheCollege.Domaine;
  7. using CG67.FicheCollege.Interface;
  8. namespace CG67.FicheCollege.Entrepot
  9. {
  10. public class EntrepotActionEducative : EntrepotBase, IEntrepotActionEducative
  11. {
  12. public IList<ActionEducative> GetByCodeRNEAndAnnee(string codeRNE, int annee)
  13. {
  14. //definition de l'IList de retour.
  15. IList<ActionEducative> resultat = new List<ActionEducative>();
  16. //utilisation de la connection pour sql server.
  17. using (SqlConnection connexion = new SqlConnection(this.ChaineDeConnexion))
  18. {
  19. try
  20. {
  21. //tentative de connection.
  22. connexion.Open();
  23. using (SqlCommand command = connexion.CreateCommand())
  24. {
  25. //mise en place de la requete.
  26. command.CommandText = "Select * from ActionEducative INNER JOIN Etablissement_ActionEducative ON (Etablissement_ActionEducative.IdActionEducative = ActionEducative.Id) WHERE CodeRNE = @RNE AND Annee = @Annee";
  27. //mise en place des attributs.
  28. command.Parameters.AddWithValue("@RNE", codeRNE);
  29. command.Parameters.AddWithValue("@Annee", annee);
  30. //lancement de la requete
  31. using (SqlDataReader dr = command.ExecuteReader())
  32. {
  33. //rajout des résultats de la requete dans l'IList de retour.
  34. while (dr.Read())
  35. {
  36. resultat.Add(new ActionEducative(dr["Libelle"].ToString(), Convert.ToInt32(dr["NbEleves"].ToString()), Convert.ToDouble(dr["MontantSubvention"].ToString())));
  37. }
  38. }
  39. }
  40. }
  41. catch (Exception e)
  42. {
  43. //renvoie de l'exception ...
  44. throw new Exception(e.ToString());
  45. }
  46. finally
  47. {
  48. //on ferme la connection si elle est ouverte.
  49. if (connexion.State == ConnectionState.Open)
  50. connexion.Close();
  51. }
  52. }
  53. //retour de l'IList de résultat.
  54. return resultat;
  55. }
  56. }
  57. }