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

Delphi .NET Discussion :

Accès aux bases de données via les objets de Borland (Bdpxx)


Sujet :

Delphi .NET

  1. #1
    Membre à l'essai
    Inscrit en
    Mai 2002
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 13
    Points : 11
    Points
    11
    Par défaut Accès aux bases de données via les objets de Borland (Bdpxx)
    Bonjour à tous !

    Voici un petit problème que je cherche à résoudre :

    Afficher le résultat de la requête suivante dans un DbWebDataGrid

    SELECT ProductName, CategoryName
    FROM Products P LEFT OUTER JOIN Categories C
    ON P.CategoryID = C.CategoryID
    En soi, ce n'est pas bien compliqué me direz-vous mais je n'ai trouvé aucun exemple ni dans "Delphi for .NET Developer's Guide" ni dans l'une ou l'autre FAQ.

    Par contre, des 'SELECT * FROM Products' j'en ai trouvé des tonnes !

    La requête est effectuée sur la db Northwind de Microsoft.

    Bon amusement !

    [Modération]
    Merci d'utiliser les balises code ou quote, Laurent Dardenne
    [/Modération]

  2. #2
    Membre émérite
    Avatar de Merlin
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mars 2002
    Messages
    524
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Mars 2002
    Messages : 524
    Points : 2 883
    Points
    2 883
    Par défaut
    le mieux est que tu regardes dans les démos livrées avec Delphi, il y a des exemples pour le composants DBWeb.

  3. #3
    Membre à l'essai
    Inscrit en
    Mai 2002
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 13
    Points : 11
    Points
    11
    Par défaut
    La démo livrée avec Delphi :
    SELECT * FROM Employee.

    Merci mais cela ne m'aide en aucune manière vu que je recherche un exemple avec une JOINTURE.

  4. #4
    Membre émérite
    Avatar de Merlin
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mars 2002
    Messages
    524
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Mars 2002
    Messages : 524
    Points : 2 883
    Points
    2 883
    Par défaut
    Citation Envoyé par agodinasandrien
    La démo livrée avec Delphi :
    SELECT * FROM Employee.

    Merci mais cela ne m'aide en aucune manière vu que je recherche un exemple avec une JOINTURE.
    Que la requête soit un select simple ou avec jointure sur 25 tables cela ne change rien à la façon d'affichier le résultat. je ne comprends pas ton problème donc...

  5. #5
    Membre à l'essai
    Inscrit en
    Mai 2002
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 13
    Points : 11
    Points
    11
    Par défaut
    Citation Envoyé par Merlin
    Citation Envoyé par agodinasandrien
    La démo livrée avec Delphi :
    SELECT * FROM Employee.

    Merci mais cela ne m'aide en aucune manière vu que je recherche un exemple avec une JOINTURE.
    Que la requête soit un select simple ou avec jointure sur 25 tables cela ne change rien à la façon d'affichier le résultat. je ne comprends pas ton problème donc...
    J'utilise un BDPDataAdapter, est-ce la bonne solution ? Avec un BDPCommand, je devrai utiliser un datareader qui ne convient pas avec un datagrid vu qu'il ne parcours les données que dans un seul sens.
    D'où ma question initiale.
    Dois-je utiliser une stored procedure ou une vue en lieu et place de la simple requête ?

  6. #6
    Membre émérite
    Avatar de Merlin
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mars 2002
    Messages
    524
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Mars 2002
    Messages : 524
    Points : 2 883
    Points
    2 883
    Par défaut
    Citation Envoyé par agodinasandrien
    J'utilise un BDPDataAdapter, est-ce la bonne solution ? Avec un BDPCommand, je devrai utiliser un datareader qui ne convient pas avec un datagrid vu qu'il ne parcours les données que dans un seul sens.
    D'où ma question initiale.
    Dois-je utiliser une stored procedure ou une vue en lieu et place de la simple requête ?
    ADO.NET est un système totalement déconnecté. Le BDP remplace les providers de ADO.NET mais c'est tout, son fonctionnement est rigoureusement identique et compatible avec tous les mécanismes ADO.NET.
    Donc que tu utilises le BDP ou les classes ADO.NET pour te connecter et envoyer tes requêtes, cela ne changera pas la logique, les possibilités et la nature déconnectée de ADO.NET.
    De fait, les accès aux données sont read only et non navigationnel. BDP ou non.
    Les données sont soient parcourues dans l'ordre tel qu'il est retourné par la base, soit elles sont stockées dans un DataSet dont c'est en partie le job d'autoriser les mouvements.
    Tu peux aussi stocker directement dans un DataTable sans passer par un DataSet (qui ne fait que stocker des DataTables et leurs relations).

    Le DataAdapter, qu'il vienne du BDP ou non, permet notamment de remplir un DataSet. Tu connectes ensuite ce dernier à la grille et tu auras ton affichage.

  7. #7
    Membre expérimenté
    Avatar de Harry
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juillet 2002
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 224
    Points : 1 331
    Points
    1 331
    Par défaut
    Oui, le BDPDataAdapter semble etre la bonne solution, si tu regardes dans l'aide de delphi tu devrais trouver une explication etape par etape te permettant de faire un simple select, à toi après de modifier le SQL une fois que ton select marchera.

  8. #8
    Membre à l'essai
    Inscrit en
    Mai 2002
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 13
    Points : 11
    Points
    11
    Par défaut
    Citation Envoyé par Harry
    Oui, le BDPDataAdapter semble etre la bonne solution, si tu regardes dans l'aide de delphi tu devrais trouver une explication etape par etape te permettant de faire un simple select, à toi après de modifier le SQL une fois que ton select marchera.
    Le pire dans l'histoire, c'est que j'arrive au bon résultat avec le SqlDataAdapter (2 min 30 sec pour effectuer toutes les opérations nécessaires au bon fonctionnement) et que le BdpDataAdapter ne me donne que des problèmes. Le malheur c'est que je vais devoir utiliser ce (censuré) de BdpDataAdapter sur une DB Interbase pour un développement WEB !

    Exemple de problème : à peine avoir introduit la requête sql dans la propriété CommandText, ce cher Bdp me donne ce joli petit message :
    Table mapping update failed : Index was outside the bounds of the array

  9. #9
    Membre expérimenté
    Avatar de Harry
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juillet 2002
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 224
    Points : 1 331
    Points
    1 331
    Par défaut
    Je dois dire que ce message la je ne l'ai pas eu dans mes tests. T'as essaye avec un simple 'select * from TABLE' ? Tu utilise l'assistant pour remplir tes 'command' ?

  10. #10
    Membre à l'essai
    Inscrit en
    Mai 2002
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 13
    Points : 11
    Points
    11
    Par défaut
    Que j'utilise l'assistant ou que je le fasse manuellement, j'ai ce message. Que je parte d'une app existante ou d'une nouvelle, même topo. Je commence à croire que Borland tombe dans les travers de MS au début de Visual Basic des années 90 !
    Et pourtant je travaille avec Delphi depuis la version 1 et Turbo pascal 5.5 c'est dire !

Discussions similaires

  1. Réponses: 3
    Dernier message: 06/10/2006, 17h05
  2. Pilote d'accés aux bases de données
    Par aragom dans le forum Bases de données
    Réponses: 3
    Dernier message: 10/05/2005, 10h06
  3. Acces à une base de données via ODBC
    Par jyg dans le forum MFC
    Réponses: 4
    Dernier message: 23/03/2005, 14h56
  4. Accès aux base de données sous Delphi 7 Edition Studio Perso
    Par renorx dans le forum Bases de données
    Réponses: 4
    Dernier message: 16/02/2005, 14h24
  5. Accès aux bases de données Access
    Par xela dans le forum C++Builder
    Réponses: 3
    Dernier message: 15/12/2004, 09h07

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