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

PHP & Base de données Discussion :

methode optimisée d'insertion de données


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Par défaut methode optimisée d'insertion de données
    Salam; dans les sites web dynamiques y'a beaucoup de flux entre serveur est machine client , par exemple l'insertion de données:
    l'utilisateur saisie des données ensuite les inserts dans la base de données.
    par exemple dans mon cas :
    j'ai un formulaire de 10 champs= ( donc un (01) enregistrement).
    l'utilisateur valide le formulaire en moyenne trois (03) fois soit trois enregistrement l'un après l'autre.
    l'application doit géré une moyenne de 500 utilisateur.
    donc 500*3*10 !!!!!
    est ce que il est souhaitable d'enregistré information après l’autre dans la BDD , ou il y'a une autre façon de collecté tous les enregistrements de l'utilisateur sur la machine client ensuite envoyé le tout dans la base de données?

  2. #2
    Membre Expert Avatar de Marc3001
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Février 2008
    Messages
    829
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Février 2008
    Messages : 829
    Par défaut
    Ça dépend.

    Observes-tu des ralentissements ?
    Comment sont effectuées les connexions à la base de données ?
    Tes 3 requêtes sont-elles envoyées via 3 connexions différentes ou sur la même ?

    Avec un bout de code ça aiderait.

  3. #3
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Bonjour,

    Dans ce cas de figure et pour éviter les appels multiples, j'utilise ce qui est offert par SQL pour les insertions :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO t_table (fieldA, fieldB) VALUES (valueA1, valueB1), (valueA2, valueB2), ... , (valueAn, valueBn);
    Un seul appel, mais (n) enregistrements ajoutés.

  4. #4
    Membre très actif
    Avatar de Nowwis
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2009
    Messages
    406
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Somme (Picardie)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2009
    Messages : 406
    Par défaut
    Salut,

    Je suppose qu'il s'agit d'un formulaire en trois étapes.

    D'une part pour le ralentissement possible en surchargeant le serveur, et d'autre part pour la cohérence des données, je te suggérerais de stocker tes informations en SESSION (genre tes trois requêtes) et de les effectuer en même temps :

    - Tu es sur que toutes tes données sont présentes
    - Tu fait qu'un appel à ton SGBD et donc optimise le temps de réponse.

    Bien sur, t'auras toujours 3 requêtes à exécuter, mais d'un coup, donc plus rapide je pense

  5. #5
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Par défaut
    Salam ; Marc3001:
    Observes-tu des ralentissements ?
    j'ai pas encore testé , seuelemnt je cherché la bonne methode de faire ça (rien ne remplace l'expérience).
    Comment sont effectuées les connexions à la base de données ?
    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
     
    <?php
    // On se connecte à la bdd
    try
    {
    			$PARAM_hote='localhost'; // le chemin vers le serveur
    			$PARAM_nom_bd='essai'; // le nom de votre base de données
    			$PARAM_utilisateur='root'; // nom d'utilisateur pour se connecter
    			$PARAM_mot_passe=''; // mot de passe de l'utilisateur pour se connecter
    			// connexion marche trés bien avec affichage de msg erreure
     
    		// Options de connection
    			$options = array
    						(
    							PDO::MYSQL_ATTR_INIT_COMMAND    => "SET NAMES utf8" ,  // indiquer à MySQL que echanger nos données en UTF8.
    							PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION , 
    							PDO::ATTR_PERSISTENT => true
    						);
     
     
            $cbd = new PDO('mysql:host='.$PARAM_hote.';dbname='.$PARAM_nom_bd, $PARAM_utilisateur, $PARAM_mot_passe , $options  );
    }
     
    catch(PDOException $e)
    {
            echo 'Une erreur de connexion est survenue !'; $e->getMessage();
            die();
    }
    $cnx = null; // Fermeture de la connexion
    ?>
    Tes 3 requêtes sont-elles envoyées via 3 connexions différentes ou sur la même ?
    non !!! c'est la même.
    rawsrc:
    Dans ce cas de figure et pour éviter les appels multiples, j'utilise ce qui est offert par SQL pour les insertions :
    l'utilisateur peut valider un seul enregistrement ou N fois , là je peut pas cerné le nombre de fois.
    selont ton code je crois que je dois faire une boucle non !!!!
    Nawwis:
    Je suppose qu'il s'agit d'un formulaire en trois étapes.
    non il s'agit d'un formulaire avec 10 champs , le tous = un seul enregistrement.
    si l'utilisateur a un seul enregistrement de 10 champs il le valide sinon s'il a n enregistrements donc il doit validé n fois une prés une.
    afin d'éviter les n appels , je cherche une methode afin d'optimisé l'enregistrement (genre panier) une fois la saisie terminée le tous sera validé.

  6. #6
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Par défaut
    Re ; en analysant bien mon problème et en pensant a haute voie :
    1. je doit crée genre de table virtuelle pour stocké les données.
    2. lancer un programme pour les enregistrés.

    ici on doit faire appel a des triggers.
    est ce que c'est la bonne solution ?
    si oui une aide serrai souhaitable. merci

  7. #7
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Bonjour,

    Citation Envoyé par redoran Voir le message
    si l'utilisateur a un seul enregistrement de 10 champs il le valide sinon s'il a n enregistrements donc il doit validé n fois une prés une.
    afin d'éviter les n appels , je cherche une methode afin d'optimisé l'enregistrement (genre panier) une fois la saisie terminée le tous sera validé.
    Je pense que tu es en train de pondre une usine à gaz.
    Faire valider individuellement (n fois) les enregistrements les uns après les autres est bancal, tu devrais repenser ta méthode.

  8. #8
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Par défaut
    Salam ;
    Marc301:
    Comment sont effectuées les connexions à la base de données ?
    est ce que je doit faire un fichier connexion par utilisateur ou tous simplement un seul fichier cbd.inc.php suffit pour tous les utilisateurs ?
    rawrsc:
    selon votre réflexion , je dois resté sur le principe de validation enregistrement après enregistrement avec réactualisation de la page. !!!
    tous ça en utilisant les requêtes préparées vue leurs rapidités.
    s'il y'a d'autres solutions je suis preneur. merci

Discussions similaires

  1. Réponses: 1
    Dernier message: 21/04/2011, 20h45
  2. Optimisation du temps d'insertion de données
    Par pimousse9 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 12/09/2007, 18h31
  3. Optimisation insertion de données
    Par brice44 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 30/08/2007, 17h08
  4. optimisation d'insert de données
    Par barabas123 dans le forum Langage SQL
    Réponses: 12
    Dernier message: 28/08/2007, 16h19
  5. Réponses: 4
    Dernier message: 09/07/2007, 12h03

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