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

Bases de données Delphi Discussion :

selection dans un TSQLQuery


Sujet :

Bases de données Delphi

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    74
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 74
    Points : 46
    Points
    46
    Par défaut selection dans un TSQLQuery
    Bonjour à tous,

    Est-il possible de refaire une selection dans un query déja rempli ?

    Par exemple si on fait :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    myquery.SQL.Add('select * from matable where (code>10)')
    myquery.open;
    myquery.sql.clear;
    myquery.SQL.Add('select * from matable where (code<20)')
    myquery.open;
    est-ce que le dataset contient tous les enregistrments dont le code est entre 10 et 20?

    Si je demande ça c'est que j'aimerais faire une requete complexe en 2 temps et en utilisant un dataset.

    merci

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 57
    Points : 40
    Points
    40
    Par défaut
    heu et pourquoi pas faire un
    myquery.SQL.Add('select * from matable where (code<20) and (code>10)')
    myquery.open;
    ou mieu
    myquery.SQL.Add('select * from matable where code between 10 and 20')
    myquery.open;

    peux tu preciser la requete desiré en question

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    74
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 74
    Points : 46
    Points
    46
    Par défaut
    nan mais là c'est une exemple simplifié de ce que je souhaite faire.

    en fait j'ai une requete complexe à faire et si je la faisais en 2 temps elle serait plus "jolie", et je voulais savoir s'il était possible de le faire en utilisant un dataset.

    Bon je vais essayer d'expliquer précisement ce que je souhaite faire.

    Je veux les identifiants et la date des personnes ayant mi à jour une table le plus récement et ceux pour un client donné.

    la requete complete :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
    select cdeclient,user,date from matable where cdeclient= '01' and date = (select max(date) from matable where codeclient='01')
    Donc moi j'aimerias remplir mon dataset avec la prmeiere selection ("select cdeclient,user,date from matable where cdeclient= '01' ") puis faire une deuximeme selection dans mon dataset pour ne garder que les enregistrements ayant la date la plus récnete.

  4. #4
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    myquery.SQL.Add('select * from matable where (code>10)')
    myquery.SQL.add('Union');
    myquery.SQL.Add('select * from matable where (code<20)')
    myquery.open;
    Avec la commande SQL Union tu peux avoir dans un même dataset les deux ensembles de données.
    Enfin dans ton example ils risquent y avoir des doublons (code >10 et code < 20)
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 57
    Points : 40
    Points
    40
    Par défaut
    tu peux essayer avec une intersection (mais pas une union) sinon ta requete imbriqué est tres bien pour ma part.

Discussions similaires

  1. Multi-selection dans une ComboBox ?
    Par Moloko dans le forum MFC
    Réponses: 5
    Dernier message: 07/07/2021, 17h26
  2. Réponses: 8
    Dernier message: 05/05/2004, 16h28
  3. select dans un trigger sous Postgresql
    Par kastor_grog dans le forum Requêtes
    Réponses: 1
    Dernier message: 03/09/2003, 17h00
  4. [Sybase] Select dans une select loop en C
    Par Claudio dans le forum Sybase
    Réponses: 2
    Dernier message: 29/04/2003, 18h06
  5. faire un selection dans une image aves les APIs
    Par merahyazid dans le forum C++Builder
    Réponses: 3
    Dernier message: 30/04/2002, 10h44

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