Avatar billede tlofqu Nybegynder
01. marts 2001 - 18:27 Der er 2 kommentarer og
1 løsning

Udtrække data fra InterBase i Delphi

Hejsa ;)
Jeg har et problem med at udtrække data fra en InterBase-database. Jeg vil gerne have, at der skal hentes dynamisk på baggrund af et nummer. På et TIBDataset har jeg under SelectSQL skrevet: select  * from KUNDE where KUNDEID = :knr. Dette virker ikke når jeg kører nedenstående procedure! Er der nogen der har et forslag til hvordan jeg kan løse problemet?


procedure TForm1.VaelgButtonClick(Sender: TObject);
Var
  IntObj : TIntObj;
  sql : string;
  Knr : Integer;
begin

  KundeNavn.Text := KundeListbox.Items.Strings[KundeListbox.ItemIndex];
  IntObj := TIntObj(KundeListbox.Items.Objects[KundeListbox.ItemIndex]);
  Kundenr.Caption := \'Kundenummer \' + IntToStr(intobj.getint);

  knr := IntObj.GetInt;

  datasetcustomerHent.Active := true;
  datasetcustomerHent.SelectSQL;

  RensForm;
  KundeNavn.Text := datasetcustomerHent.FieldByName(\'NAVN\').asstring;

osv ...

På forhånd tak !
Avatar billede pellelil Nybegynder
01. marts 2001 - 20:10 #1
Prøv i stedet:

<SNIP>
procedure TForm1.VaelgButtonClick(Sender: TObject);
Var
  IntObj : TIntObj;
  sql : string;
  Knr : Integer;
begin

  KundeNavn.Text := KundeListbox.Items.Strings[KundeListbox.ItemIndex];
  IntObj := TIntObj(KundeListbox.Items.Objects[KundeListbox.ItemIndex]);
  Kundenr.Caption := \'Kundenummer \' + IntToStr(intobj.getint);

  knr := IntObj.GetInt;

  datasetcustomerHent.Params.ByName(\'knr\').AsInteger := Knr;
  datasetcustomerHent.Active := true;
  //datasetcustomerHent.SelectSQL;

  RensForm;
  KundeNavn.Text := datasetcustomerHent.FieldByName(\'NAVN\').asstring;

osv ...
</SNIP>

Med linie ...Params.ByName... sætter du det parameter der er i din TIBDataSet\'s SelectSQL. I dit eksempel ser det ud til at du forsøger at \"kalde SelectSQL\" dette er \"noget vrøvl\", da SelectSQL blot et en property for din TIBDataSet indeholdende det SQL script der skal fyres når du åbner dit dataset. Det er således not at sætte active := true (eller blot kalde open).
Avatar billede tlofqu Nybegynder
01. marts 2001 - 20:20 #2
Brilliant - tak !
Avatar billede pellelil Nybegynder
01. marts 2001 - 20:21 #3
Aim to please :-)
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester