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 :

retourner l'enregistrement précédent [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2006
    Messages
    1 044
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 044
    Par défaut retourner l'enregistrement précédent
    Bonjour à tous, je me demandais comment retourner l'enregistrement précédent ?
    En faites je fais un petit script qui doit afficher un lien vers la page précédente en tenant compte de la catégorie dans laquel on se trouve (retourner uniquement les enregistrement d'une catégorie précise)
    J'ai fais en plusieurs requête mais sans vraiment avoir un résultat satisfaisant.
    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
    public function s_current_position($pathcategory,$getpurl){
    		$sql = 'SELECT p.idpage
    				FROM mc_cms_page as p
    				LEFT JOIN mc_cms_category as c ON(c.idcategory = p.idcategory)
    				WHERE c.pathcategory = :pathcategory AND p.pathpage = :getpurl';
    		return frontend_db_plugins::layerPlugins()->selectOne($sql,
    		array(
    			':pathcategory'	=>	$pathcategory,
    			':getpurl'		=>	$getpurl
    		));
    	}
    	public function s_prev_cms_page($pathcategory,$prev){
    		$sql = 'SELECT p.subjectpage,p.idlang,lang.codelang,c.pathcategory,c.category
    				FROM mc_cms_page as p
    				LEFT JOIN mc_lang AS lang ON(p.idlang = lang.idlang)
    				LEFT JOIN mc_cms_category as c ON(c.idcategory = p.idcategory)
    				WHERE c.pathcategory = :pathcategory AND p.idpage < :prev';
    		return frontend_db_plugins::layerPlugins()->selectOne($sql,
    		array(
    			':pathcategory'	=>	$pathcategory,
    			':prev'			=>	$prev
    		));
    	}
    Et maintenant dans le script qui doit afficher le lien précédent :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    	$followPage = new frontend_plugins_cmsFollowPage();
    	$cposition = $followPage->s_current_position($_GET['getcat'],$_GET['getpurl']);
    	if($cposition['idpage'] != '1'){
    		$prev = $followPage->s_prev_cms_page($_GET['getcat'],$cposition['idpage']);
    		return $prev['subjectpage'];
    	}
    Je ne vois pas quel genre de requête faire pour avoir, ce que je souhaite.
    En sachant que l'identifiant :
    id courant = 5
    id précédent = 3 .... ou encore id précédent = 1

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Par défaut
    Bonjour,
    Je ne vois pas quel genre de requête faire pour avoir, ce que je souhaite.
    En sachant que l'identifiant :
    id courant = 5
    id précédent = 3 .... ou encore id précédent = 1
    En utilisant la clause "ORDER BY" ?

  3. #3
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE id < id_en_cours ORDER BY id limit 1
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  4. #4
    Membre éprouvé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2006
    Messages
    1 044
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 044
    Par défaut
    Il me retourne toujours le plus petit enregistrement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT p.subjectpage, p.idlang, lang.codelang, c.pathcategory, c.category
    FROM mc_cms_page AS p
    LEFT JOIN mc_lang AS lang ON ( p.idlang = lang.idlang )
    LEFT JOIN mc_cms_category AS c ON ( c.idcategory = p.idcategory )
    WHERE c.pathcategory = "nos-specialites"
    AND p.idpage < 3
    ORDER BY p.idpage
    LIMIT 1
    Hors je doit avoir le numéro 2 vu que je suis sur le 3

  5. #5
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Par défaut
    Re,

  6. #6
    Membre éprouvé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2006
    Messages
    1 044
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 044
    Par défaut
    A première vu c'est exactement sa, je vais maintenant modifier tout sa et avoir quelque chose de plus modulable avec mon drag and drop.
    Merci

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 02/03/2007, 17h56
  2. Valeur par défault = Enregistrement précédent
    Par Aost dans le forum Access
    Réponses: 8
    Dernier message: 04/07/2006, 22h07
  3. Réponses: 4
    Dernier message: 23/06/2006, 13h29
  4. Affichage suivant enregistrement précédent
    Par cdumas dans le forum Access
    Réponses: 8
    Dernier message: 30/04/2006, 13h11
  5. Récuperer l'enregistrement précédent.
    Par zebiloute dans le forum Langage SQL
    Réponses: 4
    Dernier message: 15/04/2004, 13h01

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