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 :

aide pour une requête sql


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    202
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2008
    Messages : 202
    Points : 60
    Points
    60
    Par défaut aide pour une requête sql
    Bonsoir,

    je viens vers vous pour vos sollicité votre aide.
    je suis bloqué avec une requête sql.

    J'utilise wordpress et la requête que j'aimerais faire est celle-ci.

    j'affiche des articles personnalisé sur mon site, et tout les articles avec comme postmeta->closed = 0
    s'affiche bien sur ma page

    la requête

    Code mysql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    					SELECT distinct wp_posts.*
    					FROM wp_posts wp_posts, wp_postmeta wp_postmeta
    					WHERE wp_posts.ID = wp_postmeta.post_id
     
    					AND wp_postmeta.meta_key = 'closed'
    					AND wp_postmeta.meta_value = '0'
     
     
    					AND wp_posts.post_status = 'publish'
    					AND wp_posts.post_type = 'test'

    ma seconde condition sql qui fonctionne également ->
    j'affiche les articles avec le postmeta1->closed=1 et aussi postmeta2->mois=janvier

    Code mysql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    					SELECT distinct wp_posts.*
    					FROM wp_posts wp_posts, wp_postmeta wp_postmeta, wp_postmeta wp_postmeta2
    					WHERE wp_posts.ID = wp_postmeta.post_id AND wp_posts.ID = wp_postmeta2.post_id
     
    					AND wp_postmeta.meta_key = 'closed'
    					AND wp_postmeta.meta_value = '1'
     
    					AND wp_postmeta2.meta_key = 'mois' 
    					AND wp_postmeta2.meta_value = 'janvier' 
     
    					AND wp_posts.post_status = 'publish'
    					AND wp_posts.post_type = 'test'


    Maintenant ce que j'aimerais faire c'est une requête qui reprends les 2 deux requêtes

    si je devez définir en texte ça sera

    1. Affiche moi tout les articles qui sont bien ouvert (closed=0)
    2. Affiche moi également les articles qui sont fermer (closed=1) mais
    3. Mais uniquement les articles fermer pour le mois janvier

    J’espère que j'ai était compréhensible car je galère un peux

    Merci d'avance

  2. #2
    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
    Points : 44 155
    Points
    44 155
    Par défaut
    Si tu as deux requêtes qui fonctionnent, tu peux faire une UNION entre les deux.

    Au passage une jointure se fait pas JOIN pas avec WHERE
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT distinct wp_posts.*
    FROM wp_posts wp_posts
    JOIN wp_postmeta wp_postmeta ON wp_posts.ID = wp_postmeta.post_id
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    202
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2008
    Messages : 202
    Points : 60
    Points
    60
    Par défaut
    Merci je regarde cela
    :-)

  4. #4
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 235
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 235
    Points : 15 532
    Points
    15 532
    Par défaut
    il est certainement aussi possible d'utiliser les fonctions WordPress comme ça :
    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
     
    $elements = get_posts([
        "nopaging" => TRUE,
        "post_type" => "test",
        "meta_query" => [
            "relation" => "OR",
            [
                "key" => "closed",
                "value" => "1",
            ],
            [
                "relation" => "AND",
                [
                    "key" => "closed",
                    "value" => "0",
                ],
                [
                    "key" => "mois",
                    "value" => "janvier",
                ],
            ],
        ],
    ]);

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    202
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2008
    Messages : 202
    Points : 60
    Points
    60
    Par défaut
    Bonjour mathieu,

    justement la requête fonctionne très bien
    et j'ai du aussi faire en sorte que ça passe sur wordpress
    j'ai trouvé dans la doc de wordpress
    -> https://codex.wordpress.org/Class_Reference/WP_Query


    et j'ai fait comme ici


    Code php : 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
    $closed = array(
    	'meta_query' => array(
    		'relation' => 'OR',
    		array(
    			'key' => 'closed',
    			'value' => "0",
    			'compare' => '=',
    		),
    		array(
                            'relation' => 'AND',
                            array(
    				        		'key' => 'closed',
    								'value' => "1",
    								'compare' => '=',
                            ),
                            array(
    								'key' => 'mois',
    								'value' => "janvier",
    								'compare' => '=',
                            ),
    		),
    	),
    );

    :-) c'est cool

Discussions similaires

  1. Besoin d'aide pour une requête SQL
    Par FranckyVegas dans le forum Langage SQL
    Réponses: 7
    Dernier message: 27/05/2008, 20h16
  2. Besion d'aide pour une requête SQL SVP
    Par manucha dans le forum Langage SQL
    Réponses: 8
    Dernier message: 14/12/2007, 16h03
  3. aide pour une requête sql/plpgsql
    Par viny dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 09/11/2007, 11h32
  4. Besoin d'aide pour une requête SQL
    Par Borami dans le forum Langage SQL
    Réponses: 1
    Dernier message: 07/11/2005, 10h33
  5. Besoin d'aide pour une Requête SQL ...
    Par Kokito dans le forum Requêtes
    Réponses: 2
    Dernier message: 07/07/2004, 11h56

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