Problème de comprehension de code

guillaume150
Invité n'ayant pas de compte PHPfrance

01 janv. 2011, 15:54

Bonjour,

Voici une partie d'une méthode dans une class mais j'ai du mal à la comprendre, principalement les points d'interrogations, les 5 s et stmt, pouvez-vous m'expliquer? Et aussi ce code est-il "propre"?
$query = 'INSERT INTO membres(login, pass, type, hash, mail) VALUES(?,?,?,?,?)';
$stmt = $bdd->prepare($query);
$stmt->bind_param('sssss', $login, $pass, $type, $hash, $mail);
$stmt->execute();
Merci

Eléphant du PHP | 256 Messages

01 janv. 2011, 17:37

Bonjour,

Pour la propreté du code, je laisse la parole pour les spécialistes, mais a priori rien ne me chagrine. :)

Les *cinq* points d'interrogation correspondent aux *cinq* données que tu passes juste après avec bind_param.Le premier correspond à 'login", le deuxième à "pass" et ainsi de suite.

Edit
En revanche, ta requête ne fonctionnera pas, car 'sssss' n'a rien à faire dans bind_param : quelle est ton idée ?
Je retire la phrase, car je suis un âne baté. :mrgreen:

Cordialement,

Gaspard
Modifié en dernier par Castor Gaspard le 01 janv. 2011, 22:54, modifié 1 fois.

guillaume150
Invité n'ayant pas de compte PHPfrance

01 janv. 2011, 17:45

Enfaite c'est dans un tutoriel, voilà la méthode complète et ca marche très bien mais pouvez-vous tout expliquer, car même bind_param je comprend pas.
static function sauvegardeUser($login, $pass, $mail, $hash){

$bdd = utilitaire::ConnexionBDD();
$type = 'membre';
$query = 'INSERT INTO membres(login, pass, type, hash, mail) VALUES(?,?,?,?,?)';
$stmt = $bdd->prepare($query);
$stmt->bind_param('sssss', $login, $pass, $type, $hash, $mail);
$stmt->execute();

$stmt->close();
$bdd->close();
} 
Merci

ViPHP
ViPHP | 5462 Messages

02 janv. 2011, 16:28

il va binder les valeurs suivant les types, "s" correspond a "string", ca marche un peu comme un sprintf :wink:
le 1er s correspond à $login
le 2eme à $pass
...