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

MS SQL Server Discussion :

Requette de sélection inversée


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de Destiny
    Profil pro
    Inscrit en
    Février 2005
    Messages
    720
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Février 2005
    Messages : 720
    Par défaut Requette de sélection inversée
    Bonjour,

    J'ai une requette un peut bisard à faire. En fait, j'ai une liste de téléphone qui vont de 1 à 200 (pas dans la base). Un certain nombre de téléphones par exemple 1, 16, 55, 75, 98 sont attribué à des personnes. jusque là tout va bien. Mais j'aimerais pouvoir faire une requette qui m'affiche tout les numéros qui ne sont pas utilisé de 1 à 200. Je sais pas si il faut faire un compteur et ne pas afficher ceux qui sont utilisés?

    Je ne sais pas si c'est possible mais ça me serait bien utilie.

    Merci d'avance de votre aide et bonne journée à tous

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 010
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 22 010
    Billets dans le blog
    6
    Par défaut
    Rajoutez à votre modèle une table des nombre allant de 1 à n et faites une requête d'exclusion.

    Exemple :

    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
    CREATE TABLE T_NUM (I INT)
     
    INSERT INTO T_NUM VALUES (0)
    INSERT INTO T_NUM VALUES (1)
    INSERT INTO T_NUM VALUES (2)
    INSERT INTO T_NUM VALUES (3)
    INSERT INTO T_NUM VALUES (4)
    INSERT INTO T_NUM VALUES (5)
    INSERT INTO T_NUM VALUES (6)
    INSERT INTO T_NUM VALUES (7)
    INSERT INTO T_NUM VALUES (8)
    INSERT INTO T_NUM VALUES (9)
     
    INSERT INTO T_NUM
    SELECT T1.I + 10 * T2.I + 100 * T3.I
    FROM   T_NUM T1
           CROSS JOIN T_NUM T2
           CROSS JOIN T_NUM T3
    WHERE  T1.I + 10 * T2.I + 100 * T3.I BETWEEN 10 AND 200
    La requête pour trouver le n° de tel libre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT I
    FROM  T_NUM
    EXCEPT
    SELECT TEL_NUM
    FROM  T_TELPHONE
    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

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

Discussions similaires

  1. [Doctrine] Faire une sélection avec une relation "inversée"
    Par Gp2mv3 dans le forum ORM
    Réponses: 2
    Dernier message: 08/02/2011, 19h23
  2. [JList] Sélection inverse
    Par dev197 dans le forum Composants
    Réponses: 8
    Dernier message: 09/09/2009, 16h31
  3. [MySQL] Comment puis-je faire l'inverse de cette requette
    Par pierrot10 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 06/06/2007, 13h05
  4. [JTable] Comment faire pour inverser la sélection
    Par cootchy dans le forum Composants
    Réponses: 6
    Dernier message: 08/05/2005, 01h06

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