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 :

Dilemme ! enregistrement de fichier dans bdd [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    593
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2005
    Messages : 593
    Par défaut Dilemme ! enregistrement de fichier dans bdd
    Re bonjour.

    Voila j'ai un soucis sur l'enregistrement de mes liens dans ma base de données.

    Donc j'ai un formulaire avec un champ input type file ( dans lequel j'ajoute l'image de mon client. )

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <p>
    					<label class="text">Add a picture :</label><input type="file" class="text" name="IPhoto" /><span class="note">Max size : 1 Mo</span>
    				</p>
    J'enregistre l'image dans un dossier et j'ajoute le lien dans ma base de données pour l'alléger.

    Comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $nomphoto = "Pictures/Sales/{$num_photo}.{$extension_upload}";
    				$resultat = move_uploaded_file($_FILES['IPhoto']['tmp_name'],$nomphoto);
    				$sql=mysql_query("INSERT INTO `sales`(Photo) VALUES('$nomphoto')");
    Voici les solutions testée :
    - Au début je prenais le nom et le prenom que je concaténer pour faire : Nom_Prenom.extension Mais si le nom ou le prenom contiennent des caractères spéciaux le nom de fichier devient invalide => problèmes.



    ensuite j'ai essayer de récupérer l'id de mes client ( qui est en autoincrement)
    Donc je recuperer le dernier client enregistrer, je lui ajoutais 1 et javais ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $req=mysql_query("SELECT Id_sales FROM Sales ORDER BY Id_sales DESC LIMIT 1");
    				$row = mysql_fetch_array($req);
    				$num_photo_encours = $row['Id_sales']; 
    				$num_photo= $num_photo_encours + 1;
                    $nomphoto = "Pictures/Sales/{$num_photo}.{$extension_upload}";
    				$resultat = move_uploaded_file($_FILES['IPhoto']['tmp_name'],$nomphoto);
    151.extension

    Mais ici vient un probléme du fait que si je supprime une série de client ajouté dans les derniers , l'autoincrement reste a la valeur du dernier ajouté ( normal ) mais lorsque je fais ma requête il ne tient pas compte de celui ci.


    Donc voila je suis un peu bloqué sur l'enregistrement de mon nom de fichier.

    en fait il faudrait que je récupére l'id_sales sur laquelle mon client va être enregistrer mais je sais pas si c faisable de recuperer la prochaine valeurs de l'autoincrement dune table?

    Merci

  2. #2
    Membre Expert
    Avatar de ThomasR
    Homme Profil pro
    Directeur technique
    Inscrit en
    Décembre 2007
    Messages
    2 230
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2007
    Messages : 2 230
    Par défaut
    recuperer la prochaine valeurs de l'autoincrement dune table?
    C'est la dernière valeur ajoutée + 1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    $sql = mysql_query('SELECT MAX(Id_sales) As maxid FROM Sales');
    $maxid = mysql_result($sql,0,'maxid');
    $next_id = $maxid + 1;
     
    $nomphoto = 'Pictures/Sales/'.$next_id.$extension_upload;
    $resultat = move_uploaded_file($_FILES['IPhoto']['tmp_name'],$nomphoto);
    Le prochaine id enregistré sera $next_id.

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    593
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2005
    Messages : 593
    Par défaut
    Citation Envoyé par ThomasR Voir le message
    C'est la dernière valeur ajoutée + 1

    Le prochaine id enregistré sera $next_id.
    Faux !

    Ex:

    Supposons que j'ai déjà des valeurs jusque id=60

    j'ajoute 3 valeurs consécutivement > donc mon id sera respectivement de 61,62,63.

    jusque la tu es d'accord avec moi.

    Maitenant je supprime les 2 derniers enregistrement.

    Donc mon dernier id sera 61.

    Maitenant si je rajoute une valeur : mon id sera de 64 et non de 62!

    c'est la que le probléme se pose.

  4. #4
    Membre Expert
    Avatar de ThomasR
    Homme Profil pro
    Directeur technique
    Inscrit en
    Décembre 2007
    Messages
    2 230
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2007
    Messages : 2 230
    Par défaut
    Dans ce cas ajoutes l'enregistrement en DB avant de sauvegarder l'image,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    $sql_insert =mysql_query("INSERT INTO `sales`(Photo) VALUES('$nomphoto')");
    $sql_maxid = mysql_query('SELECT MAX(Id_sales) As maxid FROM Sales');
    $maxid = mysql_result($sql_maxid,0,'maxid');
     
    $nomphoto = 'Pictures/Sales/'.$next_id.$extension_upload;
    $resultat = move_uploaded_file($_FILES['IPhoto']['tmp_name'],$nomphoto);

  5. #5
    Membre très actif
    Avatar de buggen25
    Ingénieur développement logiciels
    Inscrit en
    Août 2008
    Messages
    554
    Détails du profil
    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Août 2008
    Messages : 554
    Par défaut MAX(id)
    salut;
    Je crois que le principe de fontionnement de l' AUTOINCREMENT dans mysql est le suivant :
    Si on met un zero :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    insert into table( '0',....) //il va prendre la valeur de l'autoincrément
    Si on met un numero > a l'autoincrément, il va prendre cette valeur
    exemple
    Et je soupçonne que l'incrémention de lautoincrement se fait avec des commandes DDL (language de definition de données)
    comme par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER TABLE taTable AUTO_INCREMENT = value;
    Ce qui déconseillé car les commandes DDL ne sont pas transactionnelles

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    593
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2005
    Messages : 593
    Par défaut
    Citation Envoyé par ThomasR Voir le message
    Dans ce cas ajoutes l'enregistrement en DB avant de sauvegarder l'image,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    $sql_insert =mysql_query("INSERT INTO `sales`(Photo) VALUES('$nomphoto')");
    $sql_maxid = mysql_query('SELECT MAX(Id_sales) As maxid FROM Sales');
    $maxid = mysql_result($sql_maxid,0,'maxid');
     
    $nomphoto = 'Pictures/Sales/'.$next_id.$extension_upload;
    $resultat = move_uploaded_file($_FILES['IPhoto']['tmp_name'],$nomphoto);
    Oui ce serait un choix.

    Mais j'ai autre chose a insérer comme valeur.

    donc je devrais faire :

    ajouter une ligne temporaire et puis faire un update de cette ligne mais bon ca fais beaucoup de requete pour peux de choses quand meme...

  7. #7
    Membre chevronné Avatar de LeGilou
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    488
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 488
    Par défaut
    Bonjour,

    Tu peux utiliser mysql_insert_id.

    Gillou.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 10/09/2007, 12h05
  2. [MySQL] Enregistrer Infos Formulaire dans Bdd
    Par jakkihm dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 07/01/2007, 17h13
  3. Enregistrer un fichier dans un programme
    Par zak39 dans le forum Signal
    Réponses: 2
    Dernier message: 29/12/2006, 17h20
  4. [servlet] enregistrer un fichier dans un serveur HTTP
    Par iam_free dans le forum Servlets/JSP
    Réponses: 3
    Dernier message: 12/04/2006, 14h58
  5. enregistrer deux fichier dans un seul fichier
    Par Bourak dans le forum Langage
    Réponses: 9
    Dernier message: 05/11/2005, 09h48

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