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

Langage PHP Discussion :

propriété "identifiant" pour une classe ? [POO]


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 495
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 495
    Billets dans le blog
    1
    Par défaut propriété "identifiant" pour une classe ?
    Bonjour,

    la notion de clé primaire existe en SQL mais rien d'équivalent en PHP/POO. Néanmoins, il faut pouvoir, lorsqu'on instancie un nouvel objet de la classe, savoir s'il faut faire un INSERT ou un UPDATE de la ou des table(s) SQL correspondante(s). Il est donc nécessaire de savoir si les propriétés de ce nouvel objet sont déjà présentes en bdd. Je me demande donc s'il faut prévoir une propriété "identifiant" qui permettrait d'identifier l'objet et donc de vérifier si son "alter ego" SQL est déjà en bdd ou non. Quel est votre avis ?

  2. #2
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 693
    Par défaut
    Les problématique SQL n'ont pas être géré en PHP.

    Savoir si tu dois insérer ou mettre à jour c'est un problème SQL qui se résout via SQL en faisant une requête du type INSERT ON DUPLICATE KEY.
    Tant que tu as tous les champs nécessaire dans ton objet c'est le moteur de BDD qui décide tout seul en fonction des contraintes que tu as appliqué
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 495
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 495
    Billets dans le blog
    1
    Par défaut
    OK,
    c'est sûrement possible mais j'ai pas trouvé : je voudrais pouvoir compter le nombre de insert et le nombre de update. Comment obtenir cette information avec un insert on duplicate key ?

  4. #4
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 693
    Par défaut
    Pas possible à ma connaissance.

    Si tu veux absolument le gérer manuellement, il suffit de regarder si ton objet à le champs de clé primaire rempli (en général l'id). Si il est rempli c'est que l'objet vient de mysql et qu'il faut donc faire un update , sinon c'est qu'il à été crée "à la main" et qu'il faut l'insérer.
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 495
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 495
    Billets dans le blog
    1
    Par défaut
    J'ai du mal à comprendre. Cela dit, dans une autre discussion (https://www.developpez.net/forums/d2.../#post11749159), j'avais donné un exemple qu'il faudrait utiliser pour préciser. J'ai mis à jour cette discussion-là, et je clos celle-ci.

  6. #6
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 693
    Par défaut
    En reprenant plus ou moins ton exemple , admettons que tu es la classe suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    class Company
    {
    	private ?int $id = null;
    	private string $label = '';
    }
    Id représentant l'id unique de ton élément dans ta bdd (en général un auto incrément).

    Si tu veux créer une Company tu vas seulement remplir le label car tu n'es pas capable via le code de déterminer quel est l'id à utiliser.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $c = new Company('my super new company');
    Donc si l'id est à null => c'est un insert que tu devras faire et la bdd se chargera de définir l'id via son autoincrément.

    Au contraire si l'id est différent de null ca veux dire que tu as peuplé ton objet avec des infos qui viennent de la bdd et qu'il faudra donc faire un update.
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  7. #7
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 369
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 369
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par laurentSc Voir le message
    OK,
    c'est sûrement possible mais j'ai pas trouvé : je voudrais pouvoir compter le nombre de insert et le nombre de update. Comment obtenir cette information avec un insert on duplicate key ?
    Avec PDO::rowCount() tu auras 1 ou 2 selon les cas. Doc MySQL :

    For INSERT ... ON DUPLICATE KEY UPDATE statements, the affected-rows value per row is 1 if the row is inserted as a new row, 2 if an existing row is updated, and 0 if an existing row is set to its current values. If you specify the CLIENT_FOUND_ROWS flag, the affected-rows value is 1 (not 0) if an existing row is set to its current values.
    https://dev.mysql.com/doc/refman/8.0...tion_row-count

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Passage d'un paramètre avec quote pour une procédure dynamique
    Par dcarroz dans le forum Développement
    Réponses: 7
    Dernier message: 26/01/2010, 12h06
  2. Héritage d'un événement pour une classe fille
    Par korntex5 dans le forum Langage
    Réponses: 4
    Dernier message: 11/01/2006, 17h48
  3. Réponses: 8
    Dernier message: 02/11/2005, 21h21
  4. ecrire un iterateur pour une classe
    Par Blowih dans le forum C++
    Réponses: 2
    Dernier message: 15/11/2004, 20h19

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