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

Requêtes MySQL Discussion :

Requête qui ne fonctionne pas avec LIMIT ?


Sujet :

Requêtes MySQL

  1. #1
    Membre à l'essai
    Homme Profil pro
    responsable RH
    Inscrit en
    Janvier 2016
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : responsable RH
    Secteur : Service public

    Informations forums :
    Inscription : Janvier 2016
    Messages : 28
    Points : 17
    Points
    17
    Par défaut Requête qui ne fonctionne pas avec LIMIT ?
    bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    	$sup = $bdd->prepare(' DELETE FROM news WHERE type=? LIMIT 2');
    	$sup->execute(array($type));
    la requette ci dessus fonctionne : elle efface les 2 plus anciennes données de ma bdd qui correspondent au 'type' qui a été déterminé dans un formulaire et enregistré dans la variable $type

    VOICI mon PROBLEME :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    	$sup = $bdd->prepare(' DELETE FROM news WHERE type=? LIMIT ?');
    	$sup->execute(array($type,$num));
    cette requete ne fonctionne pas quand je fixe la LIMIT avec un ? qui sera renseigné dans le même formuliare ...

  2. #2
    Expert éminent sénior Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 452
    Points : 19 399
    Points
    19 399
    Par défaut
    Salut jfab66.

    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
    --------------
    SET AUTOCOMMIT = 0
    --------------
     
    --------------
    START TRANSACTION
    --------------
     
    --------------
    DROP DATABASE IF EXISTS `base`
    --------------
     
    --------------
    CREATE DATABASE `base`
        DEFAULT CHARACTER SET `latin1`
        DEFAULT COLLATE       `latin1_general_ci`
    --------------
     
    --------------
    DROP TABLE IF EXISTS `test`
    --------------
     
    --------------
    CREATE TABLE `test`
    ( `id`          integer unsigned not null auto_increment primary key,
      `code`        varchar(255)     not null,
      `date_enreg`  date             not null
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    insert into `test` (`code`,`date_enreg`) values
      ('un',    '2017-03-20'),
      ('deux',  '2017-03-19'),
      ('trois', '2017-03-18'),
      ('deux',  '2017-03-17'),
      ('un',    '2017-03-16'),
      ('trois', '2017-03-15'),
      ('deux',  '2017-03-14'),
      ('un',    '2017-03-13'),
      ('deux',  '2017-03-12')
    --------------
     
    --------------
    select * from `test` order by id
    --------------
     
    +----+-------+------------+
    | id | code  | date_enreg |
    +----+-------+------------+
    |  1 | un    | 2017-03-20 |
    |  2 | deux  | 2017-03-19 |
    |  3 | trois | 2017-03-18 |
    |  4 | deux  | 2017-03-17 |
    |  5 | un    | 2017-03-16 |
    |  6 | trois | 2017-03-15 |
    |  7 | deux  | 2017-03-14 |
    |  8 | un    | 2017-03-13 |
    |  9 | deux  | 2017-03-12 |
    +----+-------+------------+
    --------------
    set @p1  = 'un'
    --------------
     
    --------------
    set @p2  = 2
    --------------
     
    --------------
    PREPARE stmt FROM 'delete from `test` where code=? order by date_enreg LIMIT ?'
    --------------
     
    --------------
    EXECUTE stmt USING @p1,@p2
    --------------
     
    --------------
    DEALLOCATE PREPARE stmt
    --------------
     
    --------------
    select * from `test`
    --------------
     
    +----+-------+------------+
    | id | code  | date_enreg |
    +----+-------+------------+
    |  1 | un    | 2017-03-20 |
    |  2 | deux  | 2017-03-19 |
    |  3 | trois | 2017-03-18 |
    |  4 | deux  | 2017-03-17 |
    |  6 | trois | 2017-03-15 |
    |  7 | deux  | 2017-03-14 |
    |  9 | deux  | 2017-03-12 |
    +----+-------+------------+
    --------------
    COMMIT
    --------------
     
    --------------
    SET AUTOCOMMIT = 1
    --------------
     
    Appuyez sur une touche pour continuer...
    Les deux lignes les plus anciennes ayant le code à 'un' ont été supprimées (id=5 et 8).

    @+

Discussions similaires

  1. REQUETE qui ne fonctionne pas avec LIMIT ?
    Par jfab66 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 20/03/2017, 11h42
  2. Requête qui ne fonctionne pas
    Par gregory.bts dans le forum JDBC
    Réponses: 1
    Dernier message: 10/06/2007, 01h11
  3. tutoriel qui ne fonctionne pas avec glassfish
    Par dev7 dans le forum Glassfish et Payara
    Réponses: 1
    Dernier message: 13/04/2007, 17h25
  4. [SQL] requête qui ne fonctionne pas
    Par marie4449 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 28/03/2007, 16h47
  5. Réponses: 10
    Dernier message: 13/03/2007, 11h38

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