Exemple compo. mysql - ttreeview - pour davix123

Description

Exemple en reponse a la question de davix123 dans le forum en reference au chargement d'une table MySql dans un TreeView :

-----------------------------
le message du forum [au cas ou il disparaisse plus tard]
----------------------- A Lire depuis la fin -------------------------------
La procedure est lancé simple par un LoadTree. Voici la partie du code qui en fait l'appel

MySQL.Host:=host;
MySQL.login:=user;
MySQL.Password:=pass;
MySQL.Database:=base;
if MySQL.Connect<0 then
begin
showmessage('PB de connexion à la base de données');
application.terminate;
end;
res:=MySQL.Query('select * FROM UTILISATEUR where IDUSER='+lid+';');
if res<>nil then
begin
try
Row := Mysql.mysql_fetch_row(Res);
while Row <nil do
begin
llogin:=row[1];
lprenom:=row[3];
lnom:=row[4];
Row := mysql.mysql_fetch_row(Res);
end;
finally
Mysql.mysql_free_result(Res);
end;
end;
Premier.Caption:=premier.Caption+' - Utilisateur : '+lprenom+' '+lnom;
Loadtree;

Jusqu'à la fin de LoadTree, tout se passe bien.

Il y a une procedure pour faire un popupmenu sur Click, en voici le code :
procedure TPremier.TreeView1Click(Sender: TObject);
var NewItem: TMenuItem;
Res : PMYSQL_RES;
Row : PMYSQL_ROW;

begin
popupmenu1.Items.Clear;
if treeview1.Selected.Level=0 then
begin
NewItem := TMenuItem.Create(PopupMenu1);
PopupMenu1.Items.Add(NewItem);
NewItem.Caption := 'Ajouter Entité ';
NewItem.Tag := 0;
NewItem.OnClick := PopupMenuItemsClick;
NewItem := TMenuItem.Create(PopupMenu1);
PopupMenu1.Items.Add(NewItem);
NewItem.Caption := 'Supprimer Entité ';
NewItem.Tag := 1;
NewItem.OnClick := PopupMenuItemsClick;
NewItem := TMenuItem.Create(PopupMenu1);
PopupMenu1.Items.Add(NewItem);
NewItem.Caption := 'Ajouter Site ';
NewItem.Tag := 2;
NewItem.OnClick := PopupMenuItemsClick;
treeview1.Selected.DeleteChildren;
if not MySQL.Connected then showmessage('Pas Connecter au serveur MySQL')
else
begin
res:=MySQL.Query('select * from SITE where IDENTITE='+inttostr(treeview1.Selected.StateIndex)+';');
treeview1.Items.AddChild(treeview1.Selected,'Coucou');
treeview1.Selected.Expand(true);
end;
end;
end;

A l'appel de Mysql.query, l'appli plante. Si j'efface ce bout de code, pour mettre juste un Mysql.Query, ça plante. Si je met de MySQL.Query à la fin de LoadTree, ça fonctionne. Par contre, ça ne me sert à rien de le mettre là.

Merci

-------------------------------
Réponse au message :
-------------------------------

Euh... Pour l'instant, je ne vois pas pourquoi ça planterait !!

Peux-tu donner le code correspondant à l'appel qui fait planter le programme ? (utilise le mode pas-à-pas...)

Merci ;o)

Bestiol.

-------------------------------
Réponse au message :
-------------------------------

Voici le code de LoadTree :

procedure TPremier.loadtree;
var Res : PMYSQL_RES;
Row : PMYSQL_ROW;
noeux : TTreenode;

begin
res:=MySQL.Query('select * FROM ENTITE;');
if res<>nil then
begin
try
Row := Mysql.mysql_fetch_row(Res);
if row=nil then
begin
noeux:=TreeView1.Items.AddChild(nil,'Aucune entité');
noeux.ImageIndex:=-1;
noeux.SelectedIndex:=-1;
end;
while Row <nil do
begin
noeux:=TreeView1.Items.AddChild(nil,row[1]);
with noeux do
begin
ImageIndex:=0;
SelectedIndex:=0;
data:=pointer(0);
StateIndex:=strtoint(row[0]);
end;
Row := mysql.mysql_fetch_row(Res);
end;
finally
Mysql.mysql_free_result(Res);
end;
end;
end;

Davix

-------------------------------
Réponse au message :
-------------------------------

Pourrais-tu nous donner le code de ta procédure LoadTree ?

Ca aiderait peut-être à voir où se situe le problème...

@+
Bestiol.

-------------------------------
Réponse au message :
-------------------------------

Bonjour,
j'utilise le composant d'alexanderpopov présent sur ce site pour faire des connexions MySQL.

Mon programme fonctionne avec une TreeView. Pour la remplir avec les données du serveur Mysql, j'ai écris une procedure LoadTree; Celle-ci rempli correctement la TreeView. Par contre, tout appel à MySQL après cette procedure fait systématiquement planté l'application.

Le Message d'erreur est : Access Violation at adresse 100060C0. Read of adresse 100060C0.

Je ne comprend pas pourquoi ?

Ma procedure est déclarée avec toutes les procedures, et dans le programme, elle est écrite de la manière suivante :

procedure TForm1.Loadtree;
begin
...
end;

Merci de votre aide.

Davix

Codes Sources

A voir également

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.