Query on the fly

Query on the fly

offline
  • Emil Beli
  • Pridružio: 03 Jan 2005
  • Poruke: 2990
  • Gde živiš: Beograd

Ja vec dosta dugo imam praksu da sve sto je moguce kreiram dinamicki, osim formi, mada i to imam obicaj ako se radi o nekoj komponenti.

Svako ko radi sa bazama podataka, ima vrlo cesto potrebu da izvrshi neki upit nad bazom. Svaki put kreirati dinamicki moze da bude nezgodno pa vam poklanjam unit koji ce vecinu stvari automatizovati za vas.

[Link mogu videti samo ulogovani korisnici]

Nekoliko reci o unitu...
Unit je napravljen za Absolute Database. Moze se jednostavno izmeniti da radi za bilo koju drugu komponentu... obican TQuery, TSDQuery,TADOQuery...i ostale

Postoji i klasa TABLQuery. Nju nemojte koristiti jer je komplikovano za objasniti. Ona radi na specifican, samo meni potreban nacin.

Kako se prilagodjava unit
-----------------------------------
Prvo je potrebno prilagoditi unit za vas slucaj. Uklonite iz USES klauzule "ABSMain". To je specificno za AbsoluteDatabase.

Ako koristite delfijeve TQuery i TDatabase komponente, onda to izgleda ovako:
1. Promenite TABQuery = class(TABSQuery) u TABQuery = class(TQuery)
*** TAbQuery mozete nazvati TPericinQuery, sve jedno...

2. pronadjite sva ponavljanja TABSDatabase i promenite u TDatabase (ili komponentu koju vi koristite

Kako se radi sa unitom
-----------------------------------

1. Stavite unit u USES tamo gde vam treba.
2. Primer koriscenja: (recimo, treba vam funkcija koja ce da vrati sumu kolicine neke robe

Primer

  1. function GetSumaKolicineCipela:integer;
  2. var
  3.   qry:TABQuery;
  4. begin
  5.   qry:=Create_Query('', DataModule1.MojaBaza);   {ovde moze odmah upit, ali ja ne volim}
  6.   try
  7.     qry.sql.text:='SELECT sum(RBA_QtnKolicina) FROM Roba WHERE                    RBA_CdiTipRobe = 1'; //cipele
  8.     qry.open;
  9.     result := qry.fields[0].asInteger;
  10.     qry.close;
  11.   finally
  12.     DeleteQuery(qry);
  13.   end;
  14. end;



Registruj se da bi učestvovao u diskusiji. Registrovanim korisnicima se NE prikazuju reklame unutar poruka.
Ko je trenutno na forumu
 

Ukupno su 965 korisnika na forumu :: 58 registrovanih, 11 sakrivenih i 896 gosta   ::   [ Administrator ] [ Supermoderator ] [ Moderator ] :: Detaljnije

Najviše korisnika na forumu ikad bilo je 3466 - dana 01 Jun 2021 17:07

Korisnici koji su trenutno na forumu:
Korisnici trenutno na forumu: 04bokibole, 357magnum, 8u47, AF-1, Apok, Arsenije, bojanM84, bojanstros9, boxbole, Bozjidar87, debeli, Demi87, Dragon Order, dukajov, kybonacci, Litostroton, LostInSpaceandTime, MB120mm, Mi lao shu, MiG-29M2, milenko crazy north, milutin134, mrkanidja, Mskok, nebidrag, nelezele, niksa517, Nobunaga, nobutado, ozzy, pein, peradetlić, PrincipL, prle122, probisic, RajkoB, raptorsi, raso76, Rebel Frank, rodoljub, ruma, S.Palestinac, sekretar, Siti2, srpskasparta, Stoilkovic, stokssone, tomigun, Trpe Grozni, vandrej, VanZan, Vatreni Zmaj, Velizar Laro, vensla, vladas87, zlaya011, zombicar153, 79693