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

Langage SQL Discussion :

besoin d'aide sur requete


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Profil pro
    Enseignant
    Inscrit en
    Décembre 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2006
    Messages : 324
    Points : 93
    Points
    93
    Par défaut besoin d'aide sur requete
    Bonsoir à tous
    voila je cherche a faire une requête sur des intervalles avec between par exemple. je sais faire sur un intervalle mais sur plusieurs????

    voila se que je fais pour un intervalle mais cela ne fonctionne pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT * FROM T_TRIBUNE WHERE TRIBUNE <> 'TRIBUNE LATERALE BOIS' BETWEEN '1257' AND '1252'
    si vous pouvez me donner un petit coup de pouce
    Merci par avance

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 108
    Points : 28 424
    Points
    28 424
    Par défaut
    En effet, il y a peu de chances pour que ça fonctionne.
    La syntaxe est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    {expression} between {valeur|expression} and {valeur|expression}
    A la lecture de ta requête, je ne comprends pas ce que tu essayes de faire.

  3. #3
    Membre régulier
    Profil pro
    Enseignant
    Inscrit en
    Décembre 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2006
    Messages : 324
    Points : 93
    Points
    93
    Par défaut
    en faite j'ai une tribune de spectateurs

    avec des place de 1 à 4000

    mais la tribune est divisée en 6 parties, donc dans une partie donnée les n° de place ne se suivent pas. je cherche a connaitre les N° de place qui ne sont pas loués. Exemple dans la tribune latérale gauche les numéros pour le rang 1 sont de 1401 à 1369 pour le rang 2 de 1383 à 1375. Je suis obligé de garder ce type de numérotation le stade est déja marqué depuis de longue date.

    la requête doit me permettre d'identifier les places libres dans un secteur précis de la tribune.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    N°	  Id_Spectateur	        Tribune	             Rang	       Place
    3785	           24	      TRIBUNE LATERALE BOIS	      15	   1381
    j'espère que j'ai été clair

    La Table tribune est faite comme ci dessus

    l'enregistrement d'un abonné se fait dans la table en réservant une place par abonné(spectateur)
    cette requette fonctionne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT PLACE FROM T_TRIBUNE WHERE PLACE >= 1375 AND  PLACE <= 1383      AND      TRIBUNE = 'TRIBUNE LATERALE BOIS'
    La question peut on le faire pour 11 intervalles différents????

    merci @+
    Philippe

  4. #4
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 801
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 801
    Points : 34 063
    Points
    34 063
    Billets dans le blog
    14
    Par défaut
    Ta première requête est fausse car il manque AND ou OR entre les deux conditions de restriction et on ne sait pas sur quelle colonne porte le BETWEEN.

    A la lecture du reste, il semble que le BETWEEN porte sur la colonne PLACE ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT * 
    FROM T_TRIBUNE 
    WHERE TRIBUNE <> 'TRIBUNE LATERALE BOIS' 
      AND PLACE BETWEEN '1257' AND '1252'
    Au passage, si la colonne PLACE est de type entier, inutile de mettre les numéros de place entre '.

    je cherche a connaitre les N° de place qui ne sont pas loués.
    Ne serait-ce pas alors les places qui n'ont pas d'Id_spectateur ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT *
    FROM T_TRIBUNE
    WHERE id_spectateur IS NULL
    ORDER BY Tribune, Rang, Place

  5. #5
    Membre régulier
    Profil pro
    Enseignant
    Inscrit en
    Décembre 2006
    Messages
    324
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Décembre 2006
    Messages : 324
    Points : 93
    Points
    93
    Par défaut
    oui peut être, mais difficile car toutes les places libres n'appartiennent pas a la tribune latérale bois. C'est pour cela qu'il faut que je fasse une requête sur des intervalles. Ou alors faire une table par tribune, uniquement avec les N° de places.
    Merci
    @+
    Philippe

    Bon courage pour ta soutenance mémoire CNAM

  6. #6
    Membre expert
    Avatar de Maljuna Kris
    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2005
    Messages
    2 613
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 613
    Points : 3 950
    Points
    3 950
    Par défaut
    Saluton,
    Tiens ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE PLACE BETWEEN '1257' AND '1252'
    je croyais qu'avec BETWEEN la syntaxe imposait l'ordre des bornes
    EXtrait de la doc
    expression BETWEEN min AND max

    Si expression est supérieure ou égale à min et expression est inférieure ou égale à max, BETWEEN retourne 1, sinon 0. Ceci est équivalent à l'expression (min <= expression AND expression <= max) si tous les arguments sont du même type. Dans tous les autres cas, la conversion de type prends place, selon les règles suivantes, mais appliquée aux trois arguments. Notez que avant la 4.0.5, les arguments étaient convertis au type de expr.

  7. #7
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 801
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 801
    Points : 34 063
    Points
    34 063
    Billets dans le blog
    14
    Par défaut
    Citation Envoyé par Philguio
    oui peut être, mais difficile car toutes les places libres n'appartiennent pas a la tribune latérale bois.
    Si tu cherches les places libres sur la tribune latérale bois, tu ajoutes une condition de restriction sur la tribune.

    Citation Envoyé par Maljuna Kris
    je croyais qu'avec BETWEEN la syntaxe imposait l'ordre des bornes
    Je n'avais pas fait attention à ce détail.

  8. #8
    Membre expert
    Avatar de Maljuna Kris
    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2005
    Messages
    2 613
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 613
    Points : 3 950
    Points
    3 950
    Par défaut
    Citation Envoyé par CinePhil Voir le message
    Je n'avais pas fait attention à ce détail.
    Ceci dit, ce n'est peut-être vrai qu'avec MySQL; et comme je passais par là....

Discussions similaires

  1. [AC-2010] besoin d aide sur requete
    Par kem77 dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 08/03/2012, 22h40
  2. Besoin d'aide sur requete SQL
    Par s.godquin dans le forum Langage SQL
    Réponses: 1
    Dernier message: 16/04/2009, 10h34
  3. Réponses: 7
    Dernier message: 18/07/2008, 09h44
  4. Besoin d'aide sur requetes imbriquées simples
    Par Kyti dans le forum Langage SQL
    Réponses: 2
    Dernier message: 01/03/2006, 10h52
  5. Besoin d'aide sur une requete ds un trigger
    Par ideal dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 15/02/2006, 10h05

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