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 :

Requêtes sur une table des départements français [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre émérite

    Profil pro
    Inscrit en
    Juin 2007
    Messages
    748
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 748
    Par défaut Requêtes sur une table des départements français
    Bonsoir,

    je dois faire un formulaire avec comme base de recherche le département, ensuite je propose les villes.

    le problème :

    certains départements de ma base sont en 4 chiffres, en fait tous les numéros commençant par 0..

    1ere solution )
    je voudrais faire un update de mes lignes dans le cas ou le strlen d'une valeur est égale à 4

    Par exemple sur une ligne le département vaut 2220, il faut que je le remplace en 02220;

    Je n'ai aucune idée de la meilleurs requête en Mysql.


    2eme solution )
    Cependant, il est peu être possible de ne pas changer les valeurs de la base de données, mais de créer une requête de recherche adéquate.


    Merci d'avance de vos conseils.
    Images attachées Images attachées  

  2. #2
    Membre émérite

    Profil pro
    Inscrit en
    Juin 2007
    Messages
    748
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 748
    Par défaut
    Bon je l'ai fait comme ca :

    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
     
     
    $bdd = new mysqlPdo;
     
    $query=" SELECT code_postal,id FROM `pjr_carte` WHERE CHAR_LENGTH(code_postal)=4  ";
     
    $liste =  $bdd->query($query,array());
     
      for ($i = 0 ; $i < count ($liste ) ; $i++ ){
     
      $cp = '0'.$liste[$i]->code_postal;
      $id = $liste[$i]->id;
     
      $updateQuery=  "UPDATE pjr_carte SET code_postal =:cp WHERE id =:id";
          try{
          $bdd->query($updateQuery,array('code_postal'=>$cp,'id'=>$id));
          }catch (Exception $e) {
          JUSC_Exception::message('Message erreur  : '.$e);		
          }
     
     
      }

    mais je pense que j'aurais pu directement le faire en mysql..

    a voir, je mets résolu si pas de réponse

    En plus

    Pour ceux qui peuvent être intéressé par la construction de la Class mysqlPdo, inspiré pour l'instant de Benjamin et du site officiel de php, ascito propose un code minimal en vue d'amélioration collectives mais surtout au rendu facile à lire....

    Les mots d'ordre : Efficacité, sécurité, lisibilité, et compréhension



    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
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    <?php
    class bdd extends PDO 
    {
    final public function __construct($dsn, $username = '', $password = '', $driverOptions = array())
        {
            $driverOptions += array(self::ATTR_ERRMODE => self::ERRMODE_EXCEPTION,
    	self::ATTR_STATEMENT_CLASS => array('Statement'));
            parent::__construct($dsn, $username, $password, $driverOptions);
        }
    }
    class Statement extends PDOStatement 
    {
     
    }
     
    abstract class _mysqlPdo
    {
     
        public function result($array)
        {
            return $array;
        }
     
        protected  function connect()
        {
            try {
            $dbh = new bdd('mysql:host=localhost;dbname=mabdd', 'root','motdepasse');
    	$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
            }
            catch (PDOException $e) {
            throw new Exception("Error occured while saving your object", null, $e);
            }
            return $dbh;
        }
     
        private function _bindParam($sth,$array){
     
        }   
        private function _prepare(){
     
        }
        private function _execute(){
     
        }
        protected  function _query($query,$array )
        {
     
            $id=0;
            $dbh = $this->connect();
            if($query==='' || $query===$this->curentQuery ){
                $sth = $this->curentQuery;
            }else{
                $sth = $dbh->prepare($query);
                $this->curentQuery = $sth;
            }
    	    if(!empty($array)){
    		foreach($array as $key =>$v ){
    		$sth->bindValue( ':'.$key ,$v);
    		}		
    	    }
             try {
     
            $sth->execute();
     
    	if(substr_count($sth->queryString,'SELECT')>0)
    	    {
    	    return $this->result($sth->fetchAll(PDO::FETCH_CLASS,'mysqlPdo'));
    	    }
    	    else{
    	    return true;
    	    }
            }
            catch (PDOException $e) {
    	    JUSC_Exception::message( $e->getMessage());		
     
            }  
     
        }
     
        abstract public function query($query,$array );
     
        }
     
        class mysqlPdo extends _mysqlPdo
        {
     
    	   public function query($query,$array )
    	   {
    	    return $this->_query($query,$array );
    	   }
     
        }
     
     
     
    ?>

  3. #3
    Expert confirmé
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Par défaut
    A moins que je ne me trompe, il manque des accolades dans ton code.

    Mais je m'interroge surtout de la pertinence de ces classes, qu'est-ce qu'elles apportent comme valeur ajoutée ?

  4. #4
    Membre émérite

    Profil pro
    Inscrit en
    Juin 2007
    Messages
    748
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 748
    Par défaut
    non pour les accolades c'est OK;

    Pour ma part j'utilise mysql depuis que j'ai commencé à bosser avec php...

    Je trouve assez intéressant et rapide d'écrire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $id=10;
    $db = new mysqlPdo;
    $result  = $db->query ( 'SELECT count (id) FROM maTable WHERE id = :id ', Array('id'=>$id)) ;
    print_r($result);
    Avec PDO il est possible d’intégrer le fait que $id soit typé, et aussi il y a une gestion des drivers..

    On peu choisir le type de réponse que l'on attends, pour ma part je suis foreach et While ( fetch ) et aussi possible

    ( les class bdd,mysqlPdo etc doivent tenir en peu de place [sans l'appel au fichier config qui donne les logs, plus sécurisé] )

    Donc le résultat de la class mysqlPdo devra pouvoir faciliter la vie de tout le monde, avoir une base cohérente et lisible ( pour la partie sécurité je me base plus sur ton boulot qd même, création des class etc), être paramétrable uniquement par un seul appel, et encore une fois avoir un résultat de retour qui sera facile à comprendre selon les habitude :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $db = new mysqlPdo;
    $id = 11;
    $query[0] =  'SELECT count (id) FROM maTable WHERE id = :id ';
    $result  = $db->query ( $query[0] , Array('id'=>$id),'object') ;
    print_r($result);
    finalement abstraire la class PDO ( en vue des utilisateurs SQL pour ma part) , avec les composant les plus utiles et les rendre humainement compréhensible

    franchement

  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 ;si j'ai bien compris :
    Par exemple sur une ligne le département vaut 2220, il faut que je le remplace en 02220
    j'ai eu le même problème , alors j'ai procéder directement dans phpadmin comme suite :
    champs aaaa : type int , taille/ valeurs 3 , Attributs UNSIGNED ZEROFILL.
    par requête c'est simple en utilisant la syntaxe du raquetteur de mysql

  6. #6
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 818
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 818
    Billets dans le blog
    14
    Par défaut
    Voilà la conséquence d'une erreur classique de typage de données !
    Un code postal, c'est un code, pas une quantité ni un nombre, on ne fait jamais de calcul dessus. Il faut donc utiliser le type CHAR(5) pour les codes postaux français.

    Idem pour tout code, référence, numéro qui n'ont aucune vocation à faire l'objet d'un calcul.

    Choisir le bon type de colonne, ça prend 2 secondes. Combien de temps pour chercher la cause du problème rencontré et le résoudre ?
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 28/02/2008, 08h17
  2. Effectuer une requête sur une table.
    Par Premium dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 25/05/2007, 16h27
  3. Recupérer le résultat d'une requête sur une table Firebird
    Par defluc dans le forum Bases de données
    Réponses: 7
    Dernier message: 20/04/2007, 18h30
  4. Réponses: 5
    Dernier message: 08/01/2007, 21h03
  5. requéte sur une table
    Par iutcien dans le forum Langage SQL
    Réponses: 1
    Dernier message: 23/06/2006, 15h42

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