IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

ASP.NET Discussion :

probleme classes asp.net


Sujet :

ASP.NET

  1. #1
    Membre très actif
    Inscrit en
    Avril 2010
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 139
    Par défaut probleme classes asp.net
    Bonjour,

    je cree un site web de reservation en ligne pour hotel, dans la creation des classes, j'ai :

    table client --> table reservation --> table reservation_typeRomms
    clientID reservationID reserv_RomID
    clientID reservationID
    RoomsID

    alors quand le client veut faire une reservation, saisie ses informations personnels + choisi le type de chambre + clique sur le button "reserver".

    comment je fais pour entrer ces informations dans les 3 table a la fois ?
    Merci.

  2. #2
    Membre très actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2007
    Messages
    871
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Février 2007
    Messages : 871
    Par défaut
    Salut,

    Tu créés une transaction et réalise tes inserts sur tes tables dedans.

    Quel est les problème en particulier ?

  3. #3
    Membre très actif
    Inscrit en
    Avril 2010
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 139
    Par défaut
    le problem pour businesslogic layer, comment je le fais pour les 3 classes ?

  4. #4
    Membre très actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2007
    Messages
    871
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Février 2007
    Messages : 871
    Par défaut
    Bon,

    C'est pas la première fois, sois plus clair dans tes questions !

    Envoie-nous du code, explique précisément ton problème, etc...

    Je ne suis pas astrologue.

  5. #5
    Membre très actif
    Inscrit en
    Avril 2010
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 139
    Par défaut
    ok merci pour la patience.

    pour ajouter un client a ma database, j'ai utilisè ce code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
     
            ProcessAddCliente addutenti = new ProcessAddCliente();
            Cliente cate = new Cliente(); // Classe client
     
            cate.Nome = nome.Text;
            cate.Cognome = cognome.Text;
            cate.Indirizzo = indirizzo.Text;
            cate.CAP = cap.Text;
            cate.Città = citta.Text;
            cate.Provincia = provincia.Text;
            cate.Nazionalità = nazionalita.Text;
            cate.Telefono = telefono.Text;
            cate.Fax = fax.Text;
            cate.Email = email.Text;
            cate.Note = Session["Note"].ToString();
     
            addutenti.Cliente = cate;
            cognome.Text = cate.ClienteID.ToString();
            try
            {
                addutenti.Invoke();
            }
    ProcessAddCliente : businesslogic layer qui contient la classe InsertClient qui execute la stored procedure Insert_client.

    tout marche tres bien, sauf j'arrive pas a recuperer l'ID du client ajouté car j'en ai besoin pour ajouter aussi sa reservation en ligne dans la table reservation.

  6. #6
    Expert confirmé
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Par défaut
    Si La requete SQL est bien faite elle doit retourner cet identifiant qui remonte au travers de la DAL jusqu'à la BLL.
    "Winter is coming" (ma nouvelle page d'accueil)

  7. #7
    Membre très actif
    Inscrit en
    Avril 2010
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 139
    Par défaut
    merci pour ta reponse mais tu peux m'expliquer plus car je suis bloquée sur ce point, voici ma stored procedure :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
     
    ALTER PROCEDURE [dbo].[Cliente_Insert]
     
    @Nome nvarchar(50),
    @Cognome nvarchar(50),
    @Indirizzo nvarchar(50),
    @CAP nvarchar(50),
    @Città nvarchar(50),
    @Provincia nvarchar(50),
    @Nazionalità nvarchar(50),
    @Telefono nvarchar(50),
    @Fax nvarchar(50),
    @Email nvarchar(50),
    @Note text
     
    AS
    INSERT INTO Cliente 
    (
    Nome,
    Cognome,
    Indirizzo,
    CAP,
    Città,
    Provincia,
    Nazionalità,
    Telefono,
    Fax,
    Email,
    Note
    ) 
    VALUES
    (
    @Nome,
    @Cognome,
    @Indirizzo,
    @CAP,
    @Città,
    @Provincia,
    @Nazionalità,
    @Telefono,
    @Fax,
    @Email,
    @Note
    )
    comment je peux faire retourner cet'identifiant ?

  8. #8
    Expert confirmé
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Par défaut
    Tu mets des caractères accentués dans ton code?????

    Pour obtenir l'identifiant généré tu peux mettre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT SCOPE_IDENTITY() AS MonIdentifiant
    après l'insertion.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    INSERT INTO Cliente 
    (
    ...
    ) 
    VALUES
    (
    ...
    )
    GO
    SELECT SCOPE_IDENTITY() AS MonIdentifiant
    A+
    "Winter is coming" (ma nouvelle page d'accueil)

  9. #9
    Membre très actif
    Inscrit en
    Avril 2010
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 139
    Par défaut
    je n'arrive pas a recuperer l'identifiant dans le BLL, merci de m'aider svp.

  10. #10
    Expert confirmé
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Par défaut
    Montre-nous chacune des méthodes dans la chaîne d’exécution stp (DAL, BLL).
    "Winter is coming" (ma nouvelle page d'accueil)

  11. #11
    Membre très actif
    Inscrit en
    Avril 2010
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 139
    Par défaut
    ok, merci :

    voici le code du button addclient :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
     
            ProcessAddCliente addutenti = new ProcessAddCliente();//bLL
            Cliente cate = new Cliente();
     
            cate.Nome = nome.Text;
            cate.Cognome = cognome.Text;
            cate.Indirizzo = indirizzo.Text;
            cate.CAP = cap.Text;
            cate.Città = citta.Text;
            cate.Provincia = provincia.Text;
            cate.Nazionalità = nazionalita.Text;
            cate.Telefono = telefono.Text;
            cate.Fax = fax.Text;
            cate.Email = email.Text;
            cate.Note = Session["Note"].ToString();
     
            addutenti.Cliente = cate;
            try
            {
                addutenti.Invoke();
            }
            catch
            {
                //Response.Redirect("../ErrorPage.aspx");
            }

    voici le code du BLL (ProcessAddClient) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    private Cliente _cliente;
     
            public Cliente Cliente
                {
                    get { return _cliente; }
                    set { _cliente = value; }
                }
     
            public ProcessAddCliente()
            {
            }
            public void Invoke()
            {
                ClienteInsertData data = new ClienteInsertData();
                data.Cliente = this.Cliente;
                data.Add();
            }
    enfin voici le code du DAL (ClienteInsertData ) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
     
    public class ClienteInsertData : DataAccessBase
        {
            private Cliente _cliente;
     
            public Cliente Cliente
                {
                get { return _cliente; }
                set { _cliente = value; }
                }
     
            private ClienteInsertDataParameters _clienteinsertdataparameters;
     
            public ClienteInsertData()
            {
                StoredProcedureName = StoredProcedure.Name.Cliente_Insert.ToString();
            }
     
            public void Add()
            {
                _clienteinsertdataparameters = new ClienteInsertDataParameters(Cliente);
                DataBaseHelper dbhelper = new DataBaseHelper( StoredProcedureName );
                dbhelper.Parameters = _clienteinsertdataparameters.Parameters;
                dbhelper.Run();
            }
        }
     
        public class ClienteInsertDataParameters
        {
            private Cliente _cliente;
     
            public Cliente Cliente
                {
                get { return _cliente; }
                set { _cliente = value; }
                }
     
            private SqlParameter[] _parameters;
     
            public ClienteInsertDataParameters(Cliente cliente)
            {
                Cliente = cliente;
                Build();
            }
     
            private void Build()
            {
                SqlParameter[] parameters =
                    {
                        new SqlParameter( "@Nome", Cliente.Nome) ,
                        new SqlParameter( "@Cognome", Cliente.Cognome),
                        new SqlParameter( "@Indirizzo", Cliente.Indirizzo),
                        new SqlParameter( "@CAP", Cliente.CAP) ,
                        new SqlParameter( "@Città", Cliente.Città) ,
                        new SqlParameter( "@Provincia", Cliente.Provincia),
                        new SqlParameter( "@Nazionalità", Cliente.Nazionalità),
                        new SqlParameter( "@Telefono", Cliente.Telefono) ,
                        new SqlParameter( "@Fax", Cliente.Fax) ,
                        new SqlParameter( "@Email", Cliente.Email),
                        new SqlParameter( "@Note", Cliente.Note)
     
                    };
                Parameters = parameters;
            }
     
     
     
            public SqlParameter[] Parameters
            {
                get { return _parameters; }
                set { _parameters = value; }
            }
        }
    maintenant je veux recupere l'id du client juste ajouté.
    merci.

  12. #12
    Expert confirmé
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Par défaut
    Mouais... Tu as beaucoup avancé sur ton architecture?

    Normalement, la DAL d'un objet métier gère toutes les opérations de maintenance de l'objet en base: insertion, lecture, mise à jour et suppression. On appelle cela le CRUD (Create, Read, Update, Delete). On ne fait pas une classe pour chaque.

    Ceci dit, il faudrait que, lorsque tu appelles la méthode ClienteInsertData.Build(), tu créés en premier (index 0) un paramètre sortant qui recueilleras la valeur de l'id créé par la base. Après avoir appelé la méthode ClienteInsertData.Run() tu récupères la valeur de ce paramètre en faisant dbhelper.Parameters[0].

    Sinon, tu peux lire ceci: http://immobilis.developpez.com/arti...ouche-asp-net/ et ceci http://immobilis.developpez.com/tuto...ity-framework/ . Il y a des exemples d'architecture.

    A+
    "Winter is coming" (ma nouvelle page d'accueil)

Discussions similaires

  1. Problem HyperLinkColumn ASP.net
    Par tunisian dans le forum ASP.NET
    Réponses: 1
    Dernier message: 20/01/2009, 14h37
  2. problem methode asp.net
    Par ado.net dans le forum ASP.NET
    Réponses: 2
    Dernier message: 24/04/2008, 13h05
  3. probleme avec asp net
    Par hakim_aya dans le forum ASP.NET
    Réponses: 1
    Dernier message: 04/04/2008, 17h45
  4. Probleme publication Asp.net sous IIS
    Par papawemba dans le forum ASP.NET
    Réponses: 3
    Dernier message: 15/02/2008, 15h02
  5. probleme avec asp.net ajax
    Par tarajji dans le forum ASP.NET
    Réponses: 3
    Dernier message: 26/03/2007, 10h43

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo