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 :

minichat -requete sql incorrect


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2012
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2012
    Messages : 12
    Par défaut minichat -requete sql incorrect
    Bonjours,
    J'ai réalisé un mini chat pour m'amuser, cependant, une requête semble poser problème. Voici le code source de la page minichat.php :

    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
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    <?php
        session_start();
    ?>
    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="utf-8" />
            <link rel="stylesheet" href="minichat.css" />
            <title>Mini-chat</title>
        </head>
        <body>
     
            <!-- formulaire !-->
     
            <?php
                if(!isset($_SESSION['pseudo']))
                {
            ?>
                    <form action="minichat_post.php" method="post">
                        <p>
                            <label for="pseudo">Votre pseudo : </label><input type="text" id="pseudo" name="pseudo" maxlength="255" /><br />
                            <label for="message">Votre message : </label><input type="text" id="message" name="message" maxlength="255" /><br />
                            <input type="submit" />
                        </p>
                    </form>
            <?php
                }
                else
                {
            ?>
                <form action="minichat_post.php" method="post">
                        <p>
                            <label for="pseudo">Votre pseudo : </label><input value="<?php echo $_SESSION['pseudo'];?>" type="text" id="pseudo" name="pseudo" maxlength="255" /><br />
                            <label for="message">Votre message : </label><input type="text" id="message" name="message" maxlength="255" /><br />
                            <input type="submit" />
                        </p>
                </form>
            <?php
                }
     
            // connexion
     
                try
                {
                    $pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
                    $bdd = new PDO('mysql:host=localhost;dbname=test', 'root', '', $pdo_options);
     
            //Selection pages de l'historique
     
                    $reponse2 = $bdd->query('SELECT count(message) as nombre FROM minichat');
     
                    $nombreEntrer = $reponse2->fetch();
                    $nombre = ceil($nombreEntrer['nombre'] / 10);
     
                    $reponse2->closeCursor();
            ?>
                    <form action="minichat.php" method="get">
                        <p>
                            <label for="page">Selectionnez la page désirée pour l'historique : </label>
                            <select id="page" name="page">
            <?php
                                for($i = 1; $i <= $nombre; $i++)
                                {
                                    $j = $i - 1;
            ?>
                                    <option value="<?php echo $j . '0';?>"><?php echo $i ;?></option>
            <?php
                                }
            ?>
                            </select> <input type="submit" />
                        </p>
                    </form>
            <?php
     
            // Affichage
     
                    if(isset($_GET['page']))
                    {
                        $reponse = $bdd->prepare('SELECT * FROM minichat ORDER BY id DESC LIMIT ?, 9');
                        $reponse->execute(array($_GET['page']));
                    }
                    else
                    {
                        $reponse = $bdd->query('SELECT * FROM minichat ORDER BY id DESC LIMIT 0, 9');
                    }
                    while($contenue = $reponse->fetch())
                    {
            ?>
                        <table>
                            <tr>
                                <td><?php echo strip_tags($contenue['pseudo']);?></td>
                                <td><?php echo strip_tags($contenue['message']);?></td>
                            </tr>
                        </table>
            <?php
                    }
                        $reponse->closeCursor();
                }
                catch(Exception $e)
                {
                    die('Erreur : ' . $e->getMessage());
                }
            ?>
            <p><a href="minichat.php">Cliquez ici pour actualiser...</a></p>
        </body>
    </html>
    La requête dans la condition
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(isset($_GET['page']))
    semble poser problème :

    Erreur : SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''00', 9' at line 1

  2. #2
    Membre Expert
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    1 051
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Hautes Pyrénées (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 051
    Par défaut
    Euh le ? est normal dans ta requête ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $reponse = $bdd->prepare('SELECT * FROM minichat ORDER BY id DESC LIMIT ?, 9');

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2012
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2012
    Messages : 12
    Par défaut
    Oui, c'est un marqueur pour ma requête préparé.
    A la ligne suivante, '?' sera remplacé par $_GET['page'] !

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Lorsque tu passes les paramètres directement dans la fonction execute, ils sont considérés automatiquement comme des chaines. Or LIMIT doit avoir besoin d'un nombre.
    Essaye en utilisant bindValue pour forcer le type :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $reponse = $bdd->prepare('SELECT * FROM minichat ORDER BY id DESC LIMIT ?, 9');
    $reponse->bindValue(1, $_GET['page'], PDO::PARAM_INT);
    $reponse->execute();
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Avril 2012
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2012
    Messages : 12
    Par défaut
    Bonsoir Celira,
    J'ai remplacer le bout de code qui n'allait pas par celui que tu m'a proposé. Apparemment, ça ne fonctionne pas car j'ai toujours le même message.

    Je te fais un copier-coller du fichier :

    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
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    <?php
    	session_start();
    ?>
    <!DOCTYPE html>
    <html>
    	<head>
    		<meta charset="utf-8" />
    		<link rel="stylesheet" href="minichat.css" />
    		<title>Mini-chat</title>
    	</head>
    	<body>
     
    		<!-- formulaire !-->
     
    		<?php
    			if(!isset($_SESSION['pseudo']))
    			{
    		?>
    				<form action="minichat_post.php" method="post">
    					<p>
    						<label for="pseudo">Votre pseudo : </label><input type="text" id="pseudo" name="pseudo" maxlength="255" /><br />
    						<label for="message">Votre message : </label><input type="text" id="message" name="message" maxlength="255" /><br />
    						<input type="submit" />
    					</p>
    				</form>
    		<?php
    			}
    			else
    			{
    		?>
    			<form action="minichat_post.php" method="post">
    					<p>
    						<label for="pseudo">Votre pseudo : </label><input value="<?php echo $_SESSION['pseudo'];?>" type="text" id="pseudo" name="pseudo" maxlength="255" /><br />
    						<label for="message">Votre message : </label><input type="text" id="message" name="message" maxlength="255" /><br />
    						<input type="submit" />
    					</p>
    			</form>
    		<?php
    			}
     
    		// connexion
     
    			try
    			{
    				$pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    				$bdd = new PDO('mysql:host=localhost;dbname=test', 'root', '', $pdo_options);
     
    		//Selection pages de l'historique
     
    				$reponse2 = $bdd->query('SELECT count(message) as nombre FROM minichat');
     
    				$nombreEntrer = $reponse2->fetch();
    				$nombre = ceil($nombreEntrer['nombre'] / 10);
     
    				$reponse2->closeCursor();
    		?>
    				<form action="minichat.php" method="get">
    					<p>
    						<label for="page">Selectionnez la page désirée pour l'historique : </label>
    						<select id="page" name="page">
    		<?php
    							for($i = 1; $i <= $nombre; $i++)
    							{
    								$j = $i - 1;
    		?>
    								<option value="<?php echo $j . '0';?>"><?php echo $i ;?></option>
    		<?php
    							}
    		?>
    						</select> <input type="submit" />
    					</p>
    				</form>
    		<?php
     
    		// Affichage
     
    				if(isset($_GET['page']))
    				{
    					$reponse = $bdd->prepare('SELECT * FROM minichat ORDER BY id DESC LIMIT ?, 9');
    					$reponse->bindValue(1, $_GET['page'], PDO::PARAM_INT);
    					$reponse->execute();
    				}
    				else
    				{
    					$reponse = $bdd->query('SELECT * FROM minichat ORDER BY id DESC LIMIT 0, 9');
    				}
    				while($contenue = $reponse->fetch())
    				{
    		?>
    					<table>
    						<tr>
    							<td><?php echo strip_tags($contenue['pseudo']);?></td>
    							<td><?php echo strip_tags($contenue['message']);?></td>
    						</tr>
    					</table>
    		<?php
    				}
    					$reponse->closeCursor();
    			}
    			catch(Exception $e)
    			{
    				die('Erreur : ' . $e->getMessage());
    			}
    		?>
    		<p><a href="minichat.php">Cliquez ici pour actualiser...</a></p>
    	</body>
    </html>
    Erreur : SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''00', 9' at line 1

Discussions similaires

  1. Problème Requete SQL et QuickReport
    Par arnaud_verlaine dans le forum C++Builder
    Réponses: 7
    Dernier message: 07/01/2004, 09h31
  2. Prob de requete sql et variable
    Par agent-zaizai dans le forum ASP
    Réponses: 11
    Dernier message: 21/10/2003, 16h54
  3. requete sql
    Par autumn319 dans le forum ASP
    Réponses: 22
    Dernier message: 10/09/2003, 16h46
  4. Paramètre requete SQL (ADOQuery)
    Par GaL dans le forum C++Builder
    Réponses: 3
    Dernier message: 30/07/2002, 11h24
  5. Resultat requete SQL
    Par PierDIDI dans le forum Bases de données
    Réponses: 2
    Dernier message: 23/07/2002, 13h43

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