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 :

Créer une table à partir d'une chaine d'ID


Sujet :

MS SQL Server

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    186
    Détails du profil
    Informations personnelles :
    Localisation : Pays-Bas

    Informations forums :
    Inscription : Décembre 2005
    Messages : 186
    Points : 133
    Points
    133
    Par défaut Créer une table à partir d'une chaine d'ID
    Bonjour,

    J'ai une requête SQL que je construis dynamiquement dans une page ASP.NET qui me pose problème. Une fois la requête construite elle se présente sous la forme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    SELECT id_1,id_2
    FROM ma_table
    WHERE
    id_1 IN (...)
    AND 
    id_2 IN (...)
    AND 
    id_3 IN (...)
    AND 
    id_4 IN (...)
    Si la taille de la chaine contenue dans le IN est modérée, la requête est très rapide mais dès que le IN contient trop d'éléments, la requête plante le server SQL.

    Avec une petite recherche sur Google j'ai trouvé un cas similaire sur un Forum ou la solution proposée était de convertir le IN en table temporaire et d'effectuer une jointure plutôt qu'une clause IN.

    Cela m'amène à 2 questions :
    - est-ce que cette solution vous parait en effet la meilleure ?

    - si oui, existe-t'il une moyen de créer une table à partir d'une chaine d'id comme "1,2,4,5,8,9..." sans avoir à faire l'insertion de chacun des id 1 à 1 ?

    Merci d'avance !

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Décembre 2006
    Messages : 69
    Points : 56
    Points
    56
    Par défaut
    Salut,

    Déjà, le problème de ta requète, c'est qu'il faut que tous les id que tu as dans la clause where existent, car si l'un d'entre eux n'existe pas, la requète ne va pas s'exécuter...

    D'autre part, pourquoi ne pas faire des vues de ce qui est entre parenthèse? A condition bien sûr que ce qui est dedans est toujours identique...

    Pour moi la meilleure solution c'est des vues intermédiaires, car la requète sera bien plus rapide ainsi, surtout si toutes les vues peuvent être synthéstisé dans une seule dans laquelle tu passes plusieurs arguments différents...

    En espérant t'avoir aidé un peu...

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    186
    Détails du profil
    Informations personnelles :
    Localisation : Pays-Bas

    Informations forums :
    Inscription : Décembre 2005
    Messages : 186
    Points : 133
    Points
    133
    Par défaut
    Salut,

    Merci pour ta réponse !
    En fait la liste d'id n'est pas fixe, c'est pour ça que je construis ma requête de manière dynamique car la liste d'id dépend des réponses que les utilisateurs auront fait à un questionnaire. Donc je ne peux pas utiliser de view ou de table autre qu'une table temporaire

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    186
    Détails du profil
    Informations personnelles :
    Localisation : Pays-Bas

    Informations forums :
    Inscription : Décembre 2005
    Messages : 186
    Points : 133
    Points
    133
    Par défaut
    J'ai finalement contourné le problème ; même si ce n'est pas terrible d'avoir plusieurs clauses IN dans une requête le problème venait surtout des clés sur la table. J'avais une clé primaire qui combinait 3 Id, et si je la supprime ma requête est instantanée. D'ailleurs je ne comprends pas vraiment pourquoi.
    Enfin mon problème de départ semble résolu !

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 22/06/2012, 12h12
  2. [Tables] Update d'une table à partir d'une autre
    Par le_niak dans le forum VBA Access
    Réponses: 2
    Dernier message: 17/01/2008, 09h01
  3. créer 2 tables à partir d'une
    Par mussara dans le forum Requêtes
    Réponses: 2
    Dernier message: 27/07/2006, 10h35
  4. copie d'une table Y d'une base A vers une table X d'une base
    Par moneyboss dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 30/08/2005, 21h24
  5. Créer une table à partir d'une autre dans un script
    Par Dam)rpgheaven dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 24/06/2005, 10h55

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