Accueil > Forum > > > > enregistrement/clé effacé
enregistrement/clé effacé
mardi 5 avril 2005 à 10:24:31 |
enregistrement/clé effacé

psycomel
|
Bonjour,
J'affiche le contenu d'un TTable dans un TDBGrid. Lorsque je double clike sur ma ligne, je veux il m'ouvre une autre petite fenêtre avec le contenu de la ligne dans des TDBEdit.
J'ai écrit le code à l'ouverture de ma petite fenêtre (FormShow) (pour avoir le droit de modifier les enregistrements ) MA_BASE.Tb_Mag.Edit;
Il m'écrit : Enregistrement/clé éffacé en msgbox directement à l'ouverture de la fenêtre. Ensuite si je veux modifier un champ, il me réécrit le même message et je ne peux rien modifer.
J'ai lu que cette erreur provenait de la modification d'un champ qui était en clé primaire. ou alors sur un autre forum j'ai aussi pu lire qu'il fallait effectuer un verrouillage pessimiste. Je n'arrive pas à faire un verrouillage pessimiste.
De plus il me semble que c'est assez courant de faire un TTable.edit; et on n'est pas beaucoup sur le net à avoir constaté cette erreur. Je veux seulement modifier une ligne de ma table !
|
|
mercredi 27 avril 2005 à 08:23:45 |
Re : enregistrement/clé effacé

mleravat
|
Slt tu ouvres une nouvelle fenetre et perd le focus sur ta base, je pense peut etre est-il bon de mettre de ne pas mettre ta base en mode Edit, de mettre ta grille en readonly et tu passes les données de ta ligne à editer dans les Tedit de ta pop up directement. Ensuite quand l'utilisateur valide les modifs et ferme la popup, tu recupère les données et les passes à ta table avec en mettant celle_ci en tabase.Edit fieldbyname('tonchamp').value:= la valeur puis tabase.post.
De Delphi 3 à 2005, les bases sont mon dada...
|
|
jeudi 28 avril 2005 à 16:46:15 |
Re : enregistrement/clé effacé

psycomel
|
Salut,
Merci pour ta réponse. Je n'ai toujours pas résolu le problème. Ca me donne une nouvelle piste. Précisement je reprend une application qui n'est pas la mienne.
Dans mon exécution j'ai la commande suivante : DM_RENO.Tb_Liste1.GotoBookmark(pointer(Liste1Frm.DBGrid1.SelectedRows.Items[0])); Je ne comprend pas ce qu'elle est sensée faire. C'est surtout le GotoBookMark que je ne comprend pas. Et aussi le pointeur. ? Après ca : Liste1Frm.DBGrid1.SelectedRows.Items[0]) ca récipère la valeur.. qui n'est d'ailleur pas la bonne... Il me récupère ce qu'il y a en colonne 2 alors que je lui demande la première (du moins la 0!)
En fait c'est cette commande qu'il me génére l'erreur : Enregistrement clé effacé.
Si je la retire.. Le code se déroule correctement. Et je ne comprend donc pas quelle serait l'utilité de ce GotoBookMark ?
Merci pour ta réponse.. Si tu pouvais simplement m'éclairer.. ce serait gentil .
|
|
vendredi 29 avril 2005 à 14:23:05 |
Re : enregistrement/clé effacé

mleravat
|
La methode GoToBookmark est une methode qui est liée à une source de données (table, datasource ou autre) et qui permet de mettre une marque sur un enregistrement de la base pour y revenir plus tard. Il faut creer une variable de type pointer "TBookmark" dans les variables globales public de l'appli puis, tu lances dans l'appli la methode create bookmark quand tu es sur l'enregistrement à memoriser, (Ex : MaTable.createbookmark(MonPointeur TBookmark) ) puis quand tu veux revenir sur cet enregistrement tu utilise la commande GoToBookmark (MonPointeur TBookmarkde type TBookmark). Ceci dis c'était la methode avec delphi 7.. avec 2005 je n'ai pas vérifié encore.
De Delphi 3 à 2005, les bases sont mon dada...
|
|
lundi 2 mai 2005 à 10:20:09 |
Re : enregistrement/clé effacé

psycomel
|
Ok, merci pour cette nouvelle réponse. J'ai compris, c cool. En ce qui concerne ma question principale avec l'erreur Enregistrement/Clé effacé. Tu me dit :
"tu ouvres une nouvelle fenetre et perd le focus sur ta base, je pense"
Il est vrai que ce message apparait souvent dans mon application. Ici par exemple il apparait comme cela : J'ai décomposé le code de mon message précédent : BM: TBookmark; BM := pointer(Liste1Frm.DBGrid1.SelectedRows.Items[i]); DM_RENO.Tb_Liste1.GotoBookmark(BM);
Il passe correctement à la deuxième ligne mais à la troisième il m'écrit le message d'erreur : Enregistrement clé effacé.
Pourtant peut avant dans la même procédure, j'ai fait : DM_RENO.Tb_Liste1.Open; Et là il ne ma pas créer de message d'erreur donc on pourrait imaginer qu'il n'a pas perdu le focus sur le base sinon il m'aurait forcement généré une erreur , non ??
ps : Je précise que Tb_Liste1 est un TTable.
|
|
jeudi 5 mai 2005 à 19:45:35 |
Re : enregistrement/clé effacé

mleravat
|
Slt, je rentre de vacances... Ok pour ton probleme effectivement si en debug la 3 ligne pose probleme c'est a cause, je pense, de BM qui n'est pas un bookmark valide, essaye de le créer ds ta procedure de la manière suivante: ( pour DELHI 6 et 7) var BM: Tbookmark; begin // BM := pointer(Liste1Frm.DBGrid1.SelectedRows.Items[i]); BM:= Tb_Liste1.getbookmark; // il cree le bookmark sur l'enregistrement actif de ta table
// quand tu veux revenir sur l'enregistrement marqué tu utilises Tb_List1.gotobookmark(BM);
BM.freeBookmark; // libère le bookmark créé pour néttoyer le pointeur; Essaye cela si ca veux marcher... A+
De Delphi 3 à 2005, les bases sont mon dada...
|
|
vendredi 6 mai 2005 à 09:01:47 |
Re : enregistrement/clé effacé
|
vendredi 6 mai 2005 à 09:55:32 |
Re : enregistrement/clé effacé

mleravat
|
ok, je crois qu'il faudrait que tu me precise qq chose, quelle est la version de delphi que tu as... et un resumé ou le fichier .pas de ce que tu veux faire, car normalement une dbgrid est directement liée à la table de ta base et tu ne devrait pas avoir à valider les modifs ou ajout de ta grille ds ta table, cela se fait tout seul à condition d'utiliser la propriété dataset de ta dbgrid. le shema normal est le suivant: tu crées un TTable lié à ta table tu crées un TDatasource lié à ta TTable et tu crées un TDbGrid lié à ton TDatasource, tu rajoutes un TDbNavigator pour avancer reculer ds ta table qui sera lié au TdataSource et ca fonctione tout seul à condition de mettre la propriété active de TTable à true. Toute modif ds la grille est automatiquement répercutée ds la table via le datasource.
De Delphi 3 à 2005, les bases sont mon dada...
|
|
mardi 10 mai 2005 à 08:53:37 |
Re : enregistrement/clé effacé

psycomel
|
Salut, j'ai la version 5 de Delphi.
Voici le code qui permettrait d'afficher dans un messagebox pour commencer les valeurs que j'ai selectionné :
procedure TForm1.Button4Click(Sender: TObject); var i: Integer; val: String; Chaine : String; //Bm: TBookmark; begin
for i:=0 to DBGrid3.SelectedRows.Count-1 do begin
//Constatation de la valeur ! Chaine:=DM_RENO.T_OPER.BookMark; //Rafraichissement DM_RENO.T_OPER.Refresh;
//Avec les deux possibilités equivalentes DBGrid3.DataSource.DataSet.GotoBookmark(pointer(DBGrid3.SelectedRows.Items[i])); //Comme il été : DM_RENO.Tb_Liste1.GotoBookmark(Bm);
val := DBGrid3.DataSource.DataSet.FieldByName('OPRIDE').AsString; ShowMessage(val);
end;
end;
T_OPER est un TTABLE
J'ai essayé sur différentes tables. Sur certaines tables ca fonctionne, sur d'autre ca ne fonctionne pas. Il faudrait savoir pourquoi il n'arrive pas à récupérer les enregistrements sur certaines tables en mettant l'erreur Enregistrement/Clé éffacé. En plus de temps en temps ca marche sur une table et puis au bout d'un moment ca ne marche plus, il remet l'erreur. Delphi n'était pas le meilleur outil pour les bases de données ??
|
|
mardi 10 mai 2005 à 13:40:10 |
Re : enregistrement/clé effacé

psycomel
|
Réponse acceptée !
Salut j'ai résolu mon problème.C cool. Enfin....... J'utilise des Tquery à la place des TTable et tout fonctionne correctement. Je place la propriété SQL avec une requête qui selectionne l'ensemble des données de la table et je place le dataset de mon datasource sur le TQuery. Je te remercie vraiment pour ton aide et tes idées. 
|
|
Cette discussion est classée dans : ligne, enregistrement, modifier, fenêtre, clé
Répondre à ce message
Sujets en rapport avec ce message
Récupérer la clé d'un enregistrement [ par freeman44 ]
Alors voila : J'exécute une requête SQL lors du clik sur un bouton: "Insert into tblEvaluateur values(nomEvaluateur, prenomEvaluateur)" Ca marche tres
EDBEngineError 'Enregistrement/Clé effacé' [ par lol_marmotte ]
j'ai une table personne avec pour clé primaire un numéro de personne puis des champs simples nom, prénom, fonction. Lorsque je veux modifier une enreg
récuperer les enregistrement d'une ligne dans une nouvelle formulaire [ par djejja ]
Salut, Je suis en cours de realiser une application avec Delphi 2005 et une base sur Paradox7 J'ai un BDGrid qui contient tous les enregistrements d
Enregistrement clé effacé [ par camis ]
Salut J'ai une application client serveur développée avec delphi 6 entreprise, la base de donnée untilisée est Oracle 8.1.7 et elle se connecte en uti
Ecrire/modifier la valeur '(défaut)' d'une clé de registre [ par mikesvl ]
Pour ce qui est de la lecture et de l'écriture de clés et/ou de valeurs dans le registre : pas de problème. Mais en ce qui concerne la valeur '(défaut
les pointeurs [ par philpas ]
Bonjour, j'ai un problème avec l'utilisation de pointeur. Je ne maitrise pas trop cette notion.J'ai simplifié pour faire court.J'ai déclarétype PLign
Modifier dynamiquement la hauteur d'une ligne d'un TstringGrid [ par furax13 ]
bonjour,j'ai un tableau composé de 2 colonnes et de 10 lignes.J'ai modifié le comportement du TStringGrid pour avoir l'affichage suivant :- 1ere colon
modifier des données dans une base deja existante [ par maxell_64 ]
Bonjours a tous, Dans un projet , j'ai une base de donnée de type paradox 7 creer en exportant une table MSAccess.Dans une form, j'ai different TEdit
imprimer un enregistrement on entrant le clé primaire [ par MLM81m ]
bonjour à tous! je suis débutant en delphi ;bon j'ai une table composer de 10 champs,je souhaite réaliser comme état de sortie c-a-d imprimer un état
Comment modifier la couleur d'une ligne de ListView ? [ par vieuxpere ]
Bonjour,Je souhaiterai savoir comment affecter par exemple la couleur ClRed à la ligne 2 ?J'ai eu beau chercher mais je n'ai pas trouvé,Merci pour vos
Livres en rapport
|
Derniers Blogs
TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3 par ROMELARD Fabrice
Speaker: Bernard Ourghanlian Cette session est comme chaque jour transmise en live par BrainSonic, et j'ai donc suivi cette troisième pleinière par ce moyen sur mon iPad . Elle est dédiée comme chaque année à la mise en perspective de l'é...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE !MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE ! par Vko
Hier durant une session dédiée aux Techdays 2012, j'ai eu le plaisir d'annoncer la sortie de la Béta 2 de Mishra Reader. C'est quoi ? Pour les utilisateurs, c'est une vraie expérience de lecture de flux RSS sur Windows. Rien à voir avec les produit...
Cliquez pour lire la suite de l'article par Vko [FRAMEWORK 4] LES TASKS ET LE THREAD UI[FRAMEWORK 4] LES TASKS ET LE THREAD UI par fathi
Je viens de passer quelques temps au TechDay's et j'ai pu voir pas mal de session intéressante. Par contre une chose m'a un peu étonné lors de certaines de ces sessions qui abordaient les améliorations du framework .NET (donc le 4.5) : en gros, bea...
Cliquez pour lire la suite de l'article par fathi WORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBEWORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBE par JeremyJeanson
Depuis déjà un an, je conseille vivement les utilisateurs de Workflow Foundation 3 à migrer vers la version 4. L'information qui va suivre ne devrait donc pas trop prendre au dépourvu les personnes qui m'ont suivi. Je profite de ce poste, pour faire le re...
Cliquez pour lire la suite de l'article par JeremyJeanson TECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PCTECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PC par ROMELARD Fabrice
Speakers: Thierry Rapatout, Antoine Petit et Xavier Trebbia Cette session entre dans le cadre des RDV Décideurs des TechDays 2012, elle est liée à la consumérisation de l'IT et la mise en place du "DeskTop as a Service" dans de plus en ...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|