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 :

SqlDataSource vs SqlCommand


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté Avatar de lapanne
    Inscrit en
    Juin 2006
    Messages
    200
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 200
    Par défaut SqlDataSource vs SqlCommand
    Bonjour,

    Je débute en .Net.
    Voilà je voudrais savoir parmi ces 2 objets (SQLDataSource et SqlCommand), quelles sont les différences ? En terme de performance, de maintenabilité du code et de la beauté du geste.
    Merci beaucoup pour les réponses que vous pourrez m'apporter

  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
    Par défaut
    SQLDataSource = Source des données SQL. Ca peut être SQL Server, MySQL, Oracle, etc...

    SqlCommand = la commande SQL (SELECT, INSERT, etc...) à exécuter

  3. #3
    Membre expérimenté Avatar de lapanne
    Inscrit en
    Juin 2006
    Messages
    200
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 200
    Par défaut
    En fait, je crois qu'il est possible de faire quelque chose comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SqlDataSource _sqlSource = new SqlDataSource();
    _sqlSource.ConnectionString = ConfigurationManager.ConnectionStrings["CoreNet_ConnectionString"].ToString();
    _sqlSource.SelectCommandType = SqlDataSourceCommandType.StoredProcedure;
    _sqlSource.SelectCommand = "SP_LstApplicationsEnfant";
    DataSourceSelectArguments params = new DataSourceSelectArguments();
    _sqlSource.Select(params );
    Ou comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    string _sqlCommand = String.Format("INSERT INTO Article (titre,auteur,date) VALUES ('{0}','{1}','{2}')",titre,auteur,date);
    OdbcCommand command = new OdbcCommand(_sqlCommand , _mySQLConnection);
    OpenConnection();
    command.ExecuteNonQuery();
    CloseConnection();
    Il s'agit d'un exemple de select ou d'insert. Donc c'est pas pareil .
    Bref je sais qu'il est possible de faire des insert, select et update avec un SqlDataSource. Perso, j'utilise des SqlCommand pour les insert, updtae, delete et des SqlDataAdapter pour les select couplés avec des dataset typé.

    Quelqu'un pourrait-il m'éclairer sur la pertinence de mon propos et les différences entre ces différentes méthodes d'accés aux données ?

    Edit : je viens de m'apercevoir que dans mon exemple, j'utilise ODBCCommand, bref, avec SqlCommand on peut faire pareil mais j'avais que ça sous la main. Daysolay

  4. #4
    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
    Par défaut
    OK donc je crois qu'un petit tour dans les cours de .NET ne serait pas un luxe.

    Ta question était: "Quelle est la différence entre SqlDataSource et SqlCommand".

    SqlDataSource = http://www.c-sharpcorner.com/UploadF...2-0aeb0e38d498

    Il s'agit d'un objet représentant une source de données SQL erver. Sur cette source, tu peux faire des INSERT, UPDATE, ETC..... Mais SqlDataSource = Sources des données SQL


    SqlCommand = La commande SQL a exécuter

    Dans ton 1er exemple, tu te connectes à un SQL Server et tu exécutes une procédure stockée.

    Dans le 2ème, tu fais un simple INSERT INTO dans une base (a priori MySQL).


    Tu ne peux pas comparer un SqlDataSource et un SqlCommand: ce sont 2 objets différents.....

  5. #5
    Membre expérimenté Avatar de lapanne
    Inscrit en
    Juin 2006
    Messages
    200
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 200
    Par défaut
    Ma question, c'était surtout dans quel cas utiliser l'un ou l'autre pour faire une insertion de données par exemple. Puisque qu'on peut le faire avec l'un ou l'autre.
    Je vais reprendre mes cours je crois.

  6. #6
    Membre habitué
    Inscrit en
    Juin 2007
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 15
    Par défaut
    Citation Envoyé par lapanne
    Je vais reprendre mes cours je crois.
    Pourtant tu as une tête de premier de la classe

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

Discussions similaires

  1. [VB.NET][2.0] SQLDataSource et Connection maintenue
    Par mout1234 dans le forum ASP.NET
    Réponses: 4
    Dernier message: 23/11/2006, 00h40
  2. [C#/ASP.Net] Pourquoi SqlCommand.Parameters.Add échoue ?
    Par focus_dotnet dans le forum Accès aux données
    Réponses: 2
    Dernier message: 25/08/2006, 17h05
  3. Réponses: 2
    Dernier message: 24/08/2006, 17h48
  4. [2.0] Chaine connexion base Access et SqlDataSource
    Par quanou dans le forum ASP.NET
    Réponses: 5
    Dernier message: 14/02/2006, 11h50
  5. SqlCommand sur SQL Server 7.0
    Par sangokus dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 08/03/2004, 10h22

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