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 :

Recuperer données d'un Recordset en ADO


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre émérite
    Avatar de amoiraud
    Homme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2006
    Messages
    606
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2006
    Messages : 606
    Par défaut Recuperer données d'un Recordset en ADO
    Bonjour à tous,
    je reviens poser une question ici vu que vous m'avez toujours aider quand j'avais un problème
    Donc je doit convertir un programme VB en C#, c'est un programme qui va lire les données dans un fichier Excel, et je n'arrive pas à récuperer les données de mon RecordSet à la position 0, voici le 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
    ADODB.Recordset Record = new ADODB.Recordset();
    string Query = " SELECT " + property;
    Query += " FROM [" + sheet + "$]";
    Query += " WHERE " + field + " = '" + objet + "'";
    string strOpen;
    strOpen = "Provider=Microsoft.Jet.OLEDB.4.0;";
    strOpen += "Data Source=" + FileName + ";";
    strOpen += "Extended Properties=Excel 8.0;HDR=" + HDRstr + ";";
    DBConnection.Open(strOpen, "", "", 0);
    Record = DBConnection.Execute(Query, out objAffected, 0);
    readpropertynorm = Record[0].Value;
    //Finally, Close the record
    Record.Close();
    La ligne que j'ai mis en gras est la ligne VB que je n'arrive pas à convertir, le "Record.Value" ne passe pas en C# (même quand je remplace les crochets par des majuscules), j'ai aussi essayé le GetString mais apparement ce n'est pas ça, donc si quelqu'un à une solution je suis preneur
    Adrien.

  2. #2
    Membre Expert
    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
    Par défaut
    Si c'est une conversion, pourquoi ne pas avoir utiliser ADO.NET et System.Data.Odbc ?

    Sinon tu peux essayer :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    string readpropertynorm = (string)Record.get_Collect("property"); // get_Collect(0) marche peut-être

  3. #3
    Membre émérite
    Avatar de amoiraud
    Homme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2006
    Messages
    606
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2006
    Messages : 606
    Par défaut
    Ca à l'air de marcher, merci bien

  4. #4
    Membre émérite
    Avatar de amoiraud
    Homme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2006
    Messages
    606
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2006
    Messages : 606
    Par défaut
    J'ai un nouveau souci, j'ai une fonction qui est censé lire une cellule Excel (avec une autre fonction plus haut qui ouvre mon DBConnection), voici la fonction Readcell :

    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
     
     
    public string ReadCell(string sheet, string column, string row)
    	{
    		useHDR=false;
    		if(useHDR==false)
    		{
    			string Query;
    			ADODB.Recordset Record = new ADODB.Recordset();
    			Query = "[" + sheet + "$" + column + row + ":" + column + row + "]";
    			Record.CursorLocation = ADODB.CursorLocationEnum.adUseClient;
    			Record.Open(Query, DBConnection, ADODB.CursorTypeEnum.adOpenStatic, ADODB.LockTypeEnum.adLockOptimistic, 0);
    			if(System.Convert.ToString(Record.Fields[0].Value)=="")
    			{
    				readcell="Cellule Vide";
    			}
    			else
    			{
    				readcell = System.Convert.ToString(Record.Fields[0].Value);
    			}
    			//Close the Recordset
    			Record.Close();
    		}
     
    		return readcell;
    	}
    Il me met une erreur à la ligne "Record.Open(Query, DBConnection, ADODB.CursorTypeEnum.adOpenStatic, ADODB.LockTypeEnum.adLockOptimistic, 0);", l'erreur est :

    Exception System.Runtime.InteropServices.COMException was thrown in debuggee:
    BOF ou EOF est égal à True ou l'enregistrement actuel a été supprimé. L'opération demandée nécessite un enregistrement actuel.
    Quelqu'un sait de quoi ca peut venir ?

Discussions similaires

  1. Réponses: 3
    Dernier message: 27/04/2006, 10h01
  2. [Tableaux] PB recuperation données type enum/set
    Par Tr@nkill dans le forum Langage
    Réponses: 2
    Dernier message: 05/04/2006, 16h49
  3. Recuperation donnée dans tierce application
    Par petitcoucou31 dans le forum Langage
    Réponses: 3
    Dernier message: 10/02/2006, 12h12
  4. Proplème de mise à jour d'un recordset par ADO
    Par maniani dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 23/01/2006, 19h14
  5. Requete sur 2 bases de donneés à partie d'un composant ADO
    Par Brice Yao dans le forum Bases de données
    Réponses: 3
    Dernier message: 21/09/2005, 16h26

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