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

Bases de données Delphi Discussion :

Faire un enregistrement avec un query


Sujet :

Bases de données Delphi

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 62
    Points : 29
    Points
    29
    Par défaut Faire un enregistrement avec un query
    bonjour à tous,

    voici mon code :

    procedure TForm6.BitBtn2Click(Sender: TObject);
    begin
    if (edit1.text='') or (edit2.text='') or (combobox1.text='') or (combobox2.text='') or (combobox3.text='') or (combobox4.text='') then
    showmessage('Vous devez remplir tous les champs')
    else
    q3.Open;
    q3.params.Items[0].asstring:=edit1.Text;
    q3.params.Items[1].asstring:=edit2.Text;
    q3.params.Items[2].asstring:=combobox4.Text;
    q3.params.Items[3].asstring:=combobox1.Text;
    q3.params.Items[4].asstring:=combobox2.Text;
    q3.params.Items[5].asstring:=combobox3.Text;
    q3.Close;
    showmessage('La nouvelle tâche a bien été enregistrée');
    edit1.Clear;
    edit2.Clear;
    Combobox4.Clear;
    Combobox1.Clear;
    Combobox2.clear;
    combobox3.clear;
    end;
    Le but du jeu >> faire un enregistrement dans une des tables de ma base de données access qui contient 6 champs. ( À noter que j'ai bien ajouter la requête sql dans la propriété "SQL" de q3 )

    Problème : actuellement on me sort le message d'erreur : "indice hors limites (0)" ... pourtant j'ai bel et bien 6 champs !!

    Merci d'avance
    Murray Moore

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 119
    Points : 125
    Points
    125
    Par défaut
    Tu fais le open avent de mettre tes paramétres. C'est plutot l'inverse qu'il faut faire.
    Mika
    www.usargancy.net

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 62
    Points : 29
    Points
    29
    Par défaut
    en plaçant le open après les q3.params... ça ne change rien
    Murray Moore

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 62
    Points : 29
    Points
    29
    Par défaut
    j'ai quelque peu changé le code ...

    procedure TForm6.BitBtn2Click(Sender: TObject);
    begin
    if (edit1.text='') or (edit2.text='') or (combobox1.text='') or (combobox2.text='') or (combobox3.text='') or (combobox4.text='') then
    showmessage('Vous devez remplir tous les champs')
    else
    q3.sql.Add('select * from tache');
    q3.open;
    q3.params[0].Value:=edit1.Text;
    q3.params[1].Value:=edit2.Text;
    q3.params[2].Value:=combobox4.Text;
    q3.params[3].Value:=combobox1.Text;
    q3.params[4].Value:=combobox2.Text;
    q3.params[5].Value:=combobox3.Text;
    showmessage('La nouvelle tâche a bien été enregistrée');
    edit1.Clear;
    edit2.Clear;
    Combobox4.Clear;
    Combobox1.Clear;
    Combobox2.clear;
    combobox3.clear;
    end;
    Toujours le même soucis : "indice de liste hors limites (0)"
    Je ne comprends vraiment pas ... ma table à bien 6 champs pourtant
    Murray Moore

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    147
    Détails du profil
    Informations personnelles :
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 147
    Points : 184
    Points
    184
    Par défaut
    Bonjour
    Le message indice hors limites (0) indique que le problème se situe au niveau du combobox probablement par le code combobox2.text=''.
    Mirmillon
    Au royaume des aveugles, les borgnes sont rois.

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 119
    Points : 125
    Points
    125
    Par défaut
    Normal tu veux affectés a tes paramétres des valeurs alors que dans ta requéte tu n'a pas de valeur

    Mais en fait tu veux faire quoi
    * récupérer un enregistrement (select * from matable)
    * insérer un enregistrement (insert into ma table ...)
    Mika
    www.usargancy.net

  7. #7
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Houla, je te conseil de fortement aller voir les tutoriaux fournis sur ce site.
    Je pense que tu n'as pas compris le fonctionnement d'une requete.

    Si tu veux insérer des données dans une table tu as deux possibilités simples :

    1- soit tu fais une requete de type insert
    2- soit tu utilises un composant TxxxTable ou TxxxQuery avec une requete "select * from LaTable".

    Si par exemple ta table a les champs : Index(champ auto incrémenté) ,Nom (VarChar),Prenom (varChar)


    Dans le premier cas

    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
    With MaQuery do
    begin
      Close; 
      SQL.Clear;
      SQL.Add('insert into (Nom,Prenom)');
      SQL.Add('values( :SNom,:SPrenom )');
      ParamCheck := True;
      Parameters.ParamByName('SNom').Value := Edit1.Text; // la syntaxe change selon le type de composants.
      Parameters.ParamByName('SPrenom').Value := Edit2.Text;
      try
        ExecSql;
      Except on E:Exception do
        Showmessage('Erreur lors de l'insertion des données : ' + E.Message);
      end;
    end;

    Dans le deuxieme cas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    With MaTable do
    begin
      Append; // insère un enregistrement vide
      FieldByName('Nom').AsString := Edit1.text;
      FieldBYName('Prenom').AsString := Edit2.text;
      try
        Post;
      Except on E:Exception do
        ShowMessage('Erreur lors de l''enregistrement des données : ' + E.MEssage);
      end;
    end;

    Voila j'espère que ca t'éclairera mais va quand même voir les tutoriels sur delphi et les base de données ainsi que les tutoriels du SQL.
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  8. #8
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 62
    Points : 29
    Points
    29
    Par défaut
    c'est pour faire des enregistrements mika ... il est vrai qu'avec le select je vais pas aller bien loin !!!!! ça paraissait pourtant évident ...

    Donc la bonne syntaxe serait :

    q3.sql.add('insert into tache');
    q3.open;
    q3.params[1].Value:=edit1.Text;
    ...
    C'est ça ?



    __________________________________________


    je viens de lire le post de malatar !

    Ok ... je vois bien le cheminement ... impec !

    Je vais aller me plonger dans les tuto encore une fois ... c'est pas gagné !

    en tout cas merci beaucoup
    Murray Moore

Discussions similaires

  1. Réponses: 2
    Dernier message: 01/05/2014, 06h08
  2. [WD17] comment faire un deuxieme enregistrement avec le même numero matricule
    Par franckmichael dans le forum WinDev
    Réponses: 6
    Dernier message: 21/01/2014, 16h39
  3. Réponses: 11
    Dernier message: 16/09/2007, 19h25
  4. Connection avec MS Query (Excel) via ODBC MySQL
    Par javigle dans le forum Installation
    Réponses: 7
    Dernier message: 23/11/2003, 21h03
  5. faire des graphiques avec Perl
    Par And_the_problem_is dans le forum Modules
    Réponses: 2
    Dernier message: 16/07/2003, 16h08

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