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 :

Retour de valeur pour une requête "select" [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2007
    Messages
    35
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 35
    Points : 24
    Points
    24
    Par défaut Retour de valeur pour une requête "select"
    Bonjour, comme indiqué dans le titre, j'ai une requête qui me permet de faire une sélection de la semaine en cours ou de la semaine suivante, requête qui est:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    $sql_week = "SELECT YEARWEEK(CURRENT_DATE( ) , 1 ) ";
    $result_sql_week = mysql_result($sql_week);
     
    if (!$result_sql_week) die('Requête invalide result_sql_week: ' . mysql_error());
     
    if ($result_sql_week == 200852 )
    	{ $salle_sem = 1;}
     
     
    if ($salle_sem == 1)
    	{$sel_sem = $result_sql_week;}
     
    Else 
    	{$sel_sem = $result_sql_week + 1;}
    Mais bien sûr, mysql_result renvoie une ressource et non le résultat de cette requête.

    Quelqu'un peut-il me dire ce que je dois utiliser dans ce cas svp? Ou bien sûr, s'il y a une meilleure façon de gérer ce que je veux faire svp?

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    154
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2003
    Messages : 154
    Points : 164
    Points
    164
    Par défaut
    salut,

    en php, tu as aussi (à tester)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    print strftime("%U"); //numéro de la semaine
    print strftime("%V"); //numéro de la semaine ISO 8601:1988
    print strftime("%W"); //numéro de la semaine où la première semaine commence le premier lundi de l'année
    ne maitrisant pas ces fonctions, je te donne le tout. C'est juste une suggestion vu que tu emploies php avec mysql.

  3. #3
    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 : 39
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Attention à ne pas confondre mysql_result qui exploite un ressource et mysql_query qui exécute une requête.

    Normalement il te faut utiliser les deux :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $sql_week = "SELECT YEARWEEK(CURRENT_DATE( ) , 1 ) ";
    $resource_sql_week = mysql_query($sql_week) or die (mysql_error());
    $result_sql_week = mysql_result($resource_sql_week, 0);
    echo $result_sql_week[0];
    Mais si tu veux simplement récupérer le numéro de la semaine courante, il ya les fonctions de temps comme suggérait Orgied, dont date fait très bien l'affaire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo date("W"); // Numéro de semaine dans l'année ISO-8601, les semaines commencent le lundi

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2007
    Messages
    35
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 35
    Points : 24
    Points
    24
    Par défaut
    En fait, vus que je fais une comparaison de ma variable après par rapport à une colonne date dans ma table donc je pensais qu'il valait mieux utiliser cette méthode. La suite donne çà:
    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
    $sql_select_salles= "SELECT * 
    FROM `salles`
    WHERE `id`=".$salle_ret;
     
    $result_select_salles = mysql_query($sql_select_salles);
    	if (!$result_select_salles) die('Requête invalide result_select_date: ' . mysql_error());
    while ($salle = mysql_fetch_object($result_select_salles)) {
     
     
     
    $sql_demande = "SELECT mag_asked_prestas.id, mag_asked_prestas.service, mag_asked_prestas.organisateur, mag_asked_prestas.objet_de_la_reunion, mag_asked_prestas.nbr_interne, mag_asked_prestas.nbr_externe, mag_prestas_date.id, mag_prestas_date.id_salle, mag_prestas_date.asked_presta_date, mag_prestas_date.asked_presta_start_time, mag_prestas_date.asked_presta_end_time
    FROM `mag_asked_prestas`
    LEFT JOIN mag_prestas_date ON ( mag_prestas_date.id_mag_asked_prestas = mag_asked_prestas.id )
    WHERE  mag_prestas_date.id_salle = '".$salle->id."' 
    AND YEARWEEK(mag_prestas_date.asked_presta_date  ,1) ='".$sel_sem."'
    ORDER BY mag_prestas_date.asked_presta_date ASC
    ";
    Mais bon, comme je disais tout à l'heure, ma méthode était peut être plus contraignante et pas assez optimisé.

    En tous cas, merci de vos réponses à tout deux

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

Discussions similaires

  1. Récupérer les valeurs d'une requête SQL dans un champs html SELECT
    Par tamiii dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 10/11/2007, 13h27
  2. [SQL 2005] Problème pour une requête SELECT
    Par Rodie dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 23/06/2007, 17h12
  3. Réponses: 3
    Dernier message: 18/06/2005, 00h31

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