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 :

Aide sur requête Enchères : meilleur enchérisseur et objet sans enchères


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    241
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2006
    Messages : 241
    Points : 89
    Points
    89
    Par défaut Aide sur requête Enchères : meilleur enchérisseur et objet sans enchères
    bonjour,

    je suis entrain de développer un système d’enchère mais je ne vois pas comment faire ma requête. En effet, je voudrais envoyer aux gens un email leurs disant qu’ils sont les meilleurs enchérisseurs et ceux pour les quels il n’y a pas eu d’enchérisseur pour que leurs objets soient enlevés.

    Comment faire ces deux requête ?

    1.choisir les meilleurs enchérisseurs dans la table offre pour leur envoyer un email
    2.choisir des objets pour lesquels il n’y a pas et d’offres pour avertir leurs propriétaires

    Voici mes tables

    Offres(#id_offre, objets_id_objet, users_speudo, date_enchere, prix_propose)
    Users(#speudo, titre, nom, prenom, adresse, code_postal, pays, telephone, email, date_naissance, mot_de_passe, ville)
    Objet(#id_objet, sous_categories_id_sous_categories, users_speudo, titre, etat, description, nombre, prix_depart, lieu, ville, payement, livraison, pas_enchere, vendu, date_debut)

    Fk04

  2. #2
    Membre actif
    Homme Profil pro
    Inscrit en
    Juin 2004
    Messages
    219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Andorre

    Informations forums :
    Inscription : Juin 2004
    Messages : 219
    Points : 241
    Points
    241
    Par défaut
    Si je n'ai mal compris

    1.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    select id_offre, max(prix_propose)
    from Offres
    2.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    select *
    from Object o
    where not o.users_speudo in (select f.users_speudo from Offres f 
                                 where f.users_speudo = o.users_speudo)

  3. #3
    Expert éminent
    Avatar de Swoög
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    6 045
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 6 045
    Points : 8 339
    Points
    8 339
    Par défaut
    Salut !

    pour la première :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    SELECT U.pseudo, U.titre, U.email, etc..., Ob.id_objet, Ob.titre, Ob.etat, etc...
    FROM Users U
       INNER JOIN Offres Of
          ON Of.user_pseudo = U.pseudo
       INNER JOIN Objets Ob
          ON Ob.id_objet = Of.objets_id_objet
    WHERE Of.prix_propose = (
       SELECT MAX(Of2.prix_propose)
       FROM Offres Of2
       WHERE Of2.objets_id_objet = Of.objets_id_objet
    )
    pour la seconde :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT U.pseudo, U.titre, U.email, etc..., Ob.id_objet, Ob.titre, Ob.etat, etc...
    FROM Users U
       INNER JOIN Objets Ob
          ON Ob.users_pseudo = U.pseudo
       LEFT JOIN Offres Of
          ON Of.objets_id_objet = Ob.id_objet
    WHERE Of.objets_id_objet IS NULL


    pour plus d'infos sur les jointures : cf tuto dans ma signature

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    241
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2006
    Messages : 241
    Points : 89
    Points
    89
    Par défaut
    Hello,

    Je viens de décortiquer les propositions et merci les gars…

    Mais j’ai encore quelques soucis :

    Pour la première requête si j’ai envie de mettre d’autres conditions il suffit de faire ceci non ?

    WHERE Of.prix_propose = (
    SELECT MAX(Of2.prix_propose)
    FROM Offres Of2
    WHERE Of2.objets_id_objet = Of.objets_id_objet
    ) and (Ob.vendu=0)

    Quant à la deuxième :

    LEFT OUTER JOIN est équivalent à LEFT JOIN ? C’est un cours de sql que j’ai en anglais….

    Si oui alors, pour moi on ne devrait pas faire Of.objets_id_objet IS NULL car une clé n’est jamais égale à null, pour moi il faudrait alors faire Of.prix_propose IS NULL

    Qu’en pensez vous ?

    Enfin j’ai encore un autre souci, j’ai des tables suivantes :

    sous_categories (#id_sous_categories, categories_id_categories, nom)
    categories (#id_categories, nom)

    J’ai envie de générer pour champ nom catégorie, ses noms sous catégories ? Comment faire ça ?
    par exemple:
    réseaux :
    cartes réseaux, routeurs, autres réseaux

    fk04

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Avril 2006
    Messages : 24
    Points : 29
    Points
    29
    Par défaut
    sous_categories (#id_sous_categories, categories_id_categories, nom)
    categories (#id_categories, nom)

    pour tes catégories / sous catégories ça n'est pas très complexe...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT sc.nom
    FROM categories c, sous_categories sc
    WHERE sc.categories_id_categories = c.id_categories AND c.nom = 'réseaux'
    Tu devrais choisir des noms d'attributs plus longs

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    241
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2006
    Messages : 241
    Points : 89
    Points
    89
    Par défaut
    hello,

    je ne pense pas... que ta proposition soit ce que je recherche

    SELECT sc.nom
    FROM categories c, sous_categories sc
    WHERE sc.categories_id_categories = c.id_categories AND c.nom = 'réseaux'

    ce que je je veux c'est qu'il liste pour chaque categorie ses sous cotegories...
    j'ai plusieurs categories et de meme plusieurs sous categories. et le lien entre ces deux tables est categories_id_categories.

    fk04

Discussions similaires

  1. Aide sur la RS 232
    Par Andr0 dans le forum C
    Réponses: 5
    Dernier message: 12/04/2005, 13h58
  2. [CR] besoin d'aide sur les formules
    Par GuillaumeDSA dans le forum Formules
    Réponses: 4
    Dernier message: 10/07/2003, 12h19
  3. Réponses: 2
    Dernier message: 27/02/2003, 01h33
  4. [Kylix] Aide sur BitBlt
    Par mic006 dans le forum EDI
    Réponses: 1
    Dernier message: 10/12/2002, 22h54
  5. Aide sur une fenetre
    Par Ray-j dans le forum Autres éditeurs
    Réponses: 4
    Dernier message: 29/11/2002, 08h51

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