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

C# Discussion :

MySQL--SQL Serveur -- DataReader "universel"


Sujet :

C#

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    612
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 612
    Points : 338
    Points
    338
    Par défaut MySQL--SQL Serveur -- DataReader "universel"
    bonjour,

    je crèè actuellement un fichier DLL contenant des fonctions qui permet d'utiliser MySQL, Access, SQL Serveur beaucoup plus facilement


    mon soucis est que, lorsque j'integre mon fichier DLL dans un nouveau projet et que je veut recuperer mon MySQLDataReader afin de remplir un liste je ne sais dans quoi le stocker.

    je m'explique, je fournis a ma DLL une requete SQL
    la DLL l'envoy au serveur et retourne un MySQLDataReader contenant le resultat de la requete

    mais je ne sais dans quoi stocker mon resultat.

    le but et de ne plus avoir besoin d'utiliser de reference aux class specifique de MySQL et autre


    avais vous un solution?

  2. #2
    Rédacteur
    Avatar de Thomas Lebrun
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    9 161
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 9 161
    Points : 19 434
    Points
    19 434
    Par défaut
    Plutôt que de renvoer un MySQLDataReader, renvoit un DbDataReader

  3. #3
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Réunion

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 277
    Points : 1 521
    Points
    1 521
    Par défaut
    Il vaudrait mieux utiliser un DataAdapter et donc des DataTable / DataSet qu'un DataReader beaucoup trop limitatif (un seul DataReader ouvert par connexion).

  4. #4
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Points : 6 334
    Points
    6 334
    Par défaut
    Citation Envoyé par Kaidan Voir le message
    Il vaudrait mieux utiliser un DataAdapter et donc des DataTable / DataSet qu'un DataReader beaucoup trop limitatif (un seul DataReader ouvert par connexion).
    Ce sont deux approches différentes, il n'y a pas lieu de dire que l'une est meilleure que l'autre... Les deux ont avantages et inconvénients.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    612
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 612
    Points : 338
    Points
    338
    Par défaut
    je ne peut pas renvoyer un System.Data.Common.DBDataReader

    en effet les objets interieures sont de type MySQL et donc incompatibles

    je ne peut pas tout changer non plus car la connexion et obligatoirement de type MySQLConnexion

  6. #6
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Réunion

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 277
    Points : 1 521
    Points
    1 521
    Par défaut
    Tous les readers dérivent de DbDataReader normalement.
    Toutes les connexions dérivent de DbConnection normalement.

    Ils devraient donc être compatibles.

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    612
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 612
    Points : 338
    Points
    338
    Par défaut
    Voici les variables que j'utilise

    Connexion : MySqlConnection
    Command : MySqlCommand
    DataReader : System.Data.Common.DbDataReader
    je fournis une requete et une connexion au Command, puis renvoy dans le DataReader avec Command.ExecutReader()

    Message d'erreur
    Impossible de convertir implicitement le type 'MySql.Data.MySqlClient.MySqlDataReader' en 'System.Data.Common.DbDataReader'

    merci de votre aide, si jamais je peut crèè une belle DLL qui permet de gèrè tout type de serveur jvous promet de la mettre en ligne




    EDIT:
    j'ai trouver la variable

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.Data.IDataReader
    qui, au 1er abord accepte les donnèes provenant d'un MySQLDataReader

    j'aurais une 2ème question

    voici une fonction qui renvoy un MySqlDataReader contenant la liste des bases de donnèes du serveur

    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
    20
    21
    22
    23
    24
    25
    public static MySqlDataReader Liste_DR
    {
        get
        {
            if (Conn != null && Conn.State == System.Data.ConnectionState.Open)
            {
                MySqlCommand Command = new MySqlCommand("SHOW DATABASES", Conn);
     
                try
                {
                    return Command.ExecuteReader();
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                    return null;
                }
            }
            else
            {
                MessageBox.Show("Impossible de récupérer la liste des bases de données du serveur car la connexion est fermée ou inexistante");
                return null;
            }
        }
    }

    pour l'utiliser correctement, dans mon interface, je crèè un System.Data.IDataReader puis je dit IDataReader = Liste_DR;

    ainsi j'ai un DataReader contenant la liste des bases et je peut travailler avec

    est-il possible de travailler directement avec Liste_DR car il correspond également a un DataReader....

  8. #8
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Réunion

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 277
    Points : 1 521
    Points
    1 521
    Par défaut

    Si il y a une erreur de conversion implicite, il faut peut-être tenter une conversion explicite ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    public System.Data.Common.DbDataReader myReader(...) {
        MySqlDataReader msdr = ...
        ...
        return (System.Data.Common.DbDataReader)msdr;
    }
    DbDataReader est disponible uniquement à partir du framework 2.0 alors que MySqlDataReader fonctionne avec toutes les versions du framework. Il est donc possible que même une conversion implicite ne fonctionne pas. Il faut donc passer par l'interface IDataReader comme tu l'as fait.

    En .NET tu manipules des références, donc faire IDataReader myreader = mysqlreader ne fait que créer une nouvelle référence vers ton mysqlreader. Tu travailles donc sur ton Liste_DR.

  9. #9
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    612
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 612
    Points : 338
    Points
    338
    Par défaut
    et pourtant quand je veut afficher sont contenu directement il me genere une erreur


    while Liste_DR.Read
    Msgbox List_DR.GetString(0)
    end while


    alors qu'avec une variable intermediaire cela fonction

  10. #10
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Réunion

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 277
    Points : 1 521
    Points
    1 521
    Par défaut
    Ca c'est normal à mon avis ... il retourne à chaque boucle une nouvelle instance.

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

Discussions similaires

  1. [PHP 5.4] passage Mysql à Sql Serveur
    Par gilles_906 dans le forum Langage
    Réponses: 18
    Dernier message: 24/10/2012, 16h33
  2. Importer une BDD de MySQL à Sql serveur 2005 ?
    Par housni dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 25/06/2007, 19h06
  3. de Mysql à sql serveur
    Par zola dans le forum JDBC
    Réponses: 3
    Dernier message: 08/11/2004, 18h02

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