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 :

Data Access System.Data.Commom


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier
    Inscrit en
    Novembre 2013
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Novembre 2013
    Messages : 11
    Par défaut Data Access System.Data.Commom
    Bonjour,

    dans le cadre de ma formation je doit réaliser une application en C# avec une connexion à une base de données.

    Je dois suivre des règles strictes mais je bloque sur la connexion.

    Voilà mon code :

    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
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    public class DataAccess
    {
    	public DataTable SetConnexion(string id)
    	{
    		DbProviderFactory factory = DbProviderFactories.GetFactory("System.Data.SqlClient");
     
    		using(DbConnection conn = factory.CreateConnection())
    		{
    			try
    			{
    				DbConnectionStringBuilder sqlclient = factory.CreateConnectionStringBuilder();
     
    				conn.ConnectionString = sqlclient.ConnectionString;
    				conn.Open();
     
    				using(DbCommand cmd = conn.CreateCommande())
    				{
    					cmd.Parameters.Add(new DbParameter(":id", id));		//Impossible de créer une instance de la classe abstraite ou de l'interface System.Data.Commom.DbParameter.
     
    					cmd.CommandText = "select * where id = :id";	
    				}
     
    				using(DataTable dt = new DataTable())
    				{
    					DbDataAdapter da = new DbDataAdapter(cmd);		//Impossible de créer une instance de la classe abstraite ou de l'interface System.Data.Commom.DbDataAdapter.
    					cmd.CommandType = CommandType.Text;
    					da.Fill(dt);
    					return dt;
    				}
    			}
    		}
    		catch(Exception ex)
    		{
    			throw new Excepton("Error", ex);
    		}
    	}
    }
    J'ai donc deux erreurs (ligne 18 & ligne 25) et je n'arrive pas à les résoudre !

    Merci d'avance pour votre aide !

  2. #2
    Membre Expert Avatar de callo
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Février 2004
    Messages
    887
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Togo

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Service public

    Informations forums :
    Inscription : Février 2004
    Messages : 887
    Par défaut
    Bonjour,
    Essayes de retourner ta connexion ave cette fonction et de l'utiliser ensuite dans l'exécution de tes requêtes:
    Code c# : 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
     
    private DbConnection _mSqlCnx;
    // Cette méthode créé une connexion à la BDD et la renvoit 
    public DbConnection GetSqlConnection()
    {
       DbProviderFactory factory = DbProviderFactories.GetFactory("System.Data.SqlClient"); 
       if (_mSqlCnx == null)
       {
            _mSqlCnx = factory.CreateConnection();
       }
       _mSqlCnx.ConnectionString = "Ta chaine de connexion ..."; 
     
       if (_mSqlCnx.State == System.Data.ConnectionState.Closed)
       {
           _mSqlCnx.Open();
       }
      return _mSqlCnx; 
     }

  3. #3
    Membre Expert Avatar de sisqo60
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2006
    Messages
    754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 754
    Par défaut
    Bonjour,

    Pour créer ton parametre utilises plutôt cmd.createparameter et pour le dbdataadapter, factory.CreateDataAdapter.

    Bon dév.

  4. #4
    Membre régulier
    Inscrit en
    Novembre 2013
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Novembre 2013
    Messages : 11
    Par défaut
    J'ai réussi pour le DataAdapter mais pas pour le paramètre.

    De plus lorsque je lance mon application, une erreur intervient : la propriété ConnectionString n'as pas été initialisée. (ligne 14)

    Que dois-je faire ?

    Merci d'avance !

  5. #5
    Membre Expert Avatar de callo
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Février 2004
    Messages
    887
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Togo

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Service public

    Informations forums :
    Inscription : Février 2004
    Messages : 887
    Par défaut
    Peux-tu montrer ton code à l'état actuel ?

  6. #6
    Membre régulier
    Inscrit en
    Novembre 2013
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Novembre 2013
    Messages : 11
    Par défaut
    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
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    public class DataAccess
    {
    	public DataTable SetConnexion(string id)
    	{
    		DbProviderFactory factory = DbProviderFactories.GetFactory("System.Data.SqlClient");
     
    		using(DbConnection conn = factory.CreateConnection())
    		{
    			try
    			{
    				DbConnectionStringBuilder sqlclient = factory.CreateConnectionStringBuilder();
     
    				conn.ConnectionString = sqlclient.ConnectionString;
    				conn.Open();
     
    				using(DbCommand cmd = conn.CreateCommande())
    				{
    					cmd.Parameters.Add(new DbParameter(":id", id));		 
    					cmd.CommandText = "select * where id = :id";	
    				}
     
    				using(DataTable dt = new DataTable())
    				{
    					DbDataAdapter da = factory.CreateDataAdapter();						cmd.CommandType = CommandType.Text;
    					da.Fill(dt);
    					return dt;
    				}
    			}
    		}
    		catch(Exception ex)
    		{
    			throw new Excepton("Error", ex);
    		}
    	}
    }
    Lorsque j'utilise F11 pour le pas à pas détaillé, je passe de conn.Open() a catch(Exception ex). Avec le message d'erreur : la propriété ConnectionString n'as pas été initialisée.

Discussions similaires

  1. [C#][Access] problème avec System.Data.Odbc
    Par l_cauchy dans le forum C#
    Réponses: 1
    Dernier message: 28/10/2009, 14h18
  2. Votre avis : ActiveX Data Object ou Data Access Object ?
    Par jfdmagic dans le forum VB 6 et antérieur
    Réponses: 0
    Dernier message: 21/04/2009, 09h36
  3. Réponses: 2
    Dernier message: 10/04/2008, 12h07
  4. Réponses: 4
    Dernier message: 22/05/2006, 11h46
  5. [Data Access Object]Intérêt de la factory ?
    Par le Daoud dans le forum Général Java
    Réponses: 2
    Dernier message: 21/04/2005, 09h06

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