Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi ibtable.Locate xy > 10 (https://www.delphipraxis.net/157428-ibtable-locate-xy-10-a.html)

JHDGE 11. Jan 2011 15:53

Datenbank: Firebird • Version: 2,0 • Zugriff über: ibexpress

ibtable.Locate xy > 10
 
Hallo
ich kenne bislang nur das ibtable.Locate bei Interbase / Firebird in der Form das ich schreibe

Delphi-Quellcode:
sqldbform.IBTable_userdat.Locate('USNUM',usernum,[locaseInsensitive,loPartialKey]) then

Also Quasi ist im Feld USNUM die usernum drinnen dann gefunden

Ich möchte jetzt aber z.B. usnum > 20 oder usnum <> 20 schreiben

Geht das auch ?

Könnte ich in der Filter Eigenschaft diese habe ich nicht nicht benutzt das auch in einem Select machen

also where usnum <> 20

Aber wie gehe ich dann durch die Table
sqldbform.IBTable_userdat.locatenext oder .next geht dann ja nicht oder

Ich habe schon alles durchgesucht finde aber nix gescheites google kennt mich nun schon mit Namen :-)

Wer könnte mir da etwas helfen ...

Danke schon mal

Joachim

hoika 11. Jan 2011 15:59

AW: ibtable.Locate xy > 10
 
Hallo,

verabschiede dich einfach von IBTable und nimm eine IB_Query.


Heiko

JHDGE 11. Jan 2011 17:03

AW: ibtable.Locate xy > 10
 
Hallo Heiko
das dachte ich mir schon das das kommt aber da habe ich doch gleich mal auch keine Ahnung von
und gefunden habe ich dann auch gleich 3 mal nix gutes habe 1000 Bücher und alles aber ich kann am meisten mit einem Beispiel anfangen

Ich habe das meiste ja auch auf Query

Könnte wahrscheinlich auch einfach umsteigen mag aber keine DBGRID verwenden und hängt das nicht zusammen ? Ich nehme Query momentan nur zum schreiben von neuen Datensätzen aber nicht zum suchen von Datensätzen dazu habe ich nichts nichts gefunden
Komme von Datenbank her aus der Dbase Codebase Abteilung

hoika 11. Jan 2011 19:49

AW: ibtable.Locate xy > 10
 
Hallo,

Zitat:

mag aber keine DBGRID verwenden
Umso besser.

Nimm ein einfaches TStringGrid, wenn du ein Grid brauchst.
Eine SQL-DB wird durch TTable nur vergew...


Heiko

joehd 11. Jan 2011 20:32

AW: ibtable.Locate xy > 10
 
hallo das mitz dem stringgrid mache ich ja wenn ich ttable benutze

aber wie such ich im ibquerry ok den sql string
select * from table where Num > 10
:glaskugel:
aber wi mach ich den next und so bitte habt Ihr du ein Beispiel ein kleines dann verstehe ich das auch
Wenn ich das richtig verstand habe dann gibt ibquery eine art Tabelle zurück. Möchte aber dann auf das Resultat zeilenorientiert zugreifen

geht das dann steige ich sofort um würde mir auch besser gefallen

Unter ibquery finde ich alles und nichts die alten Delphi Versionen hatten noch ne gescheite Hilfe ..

Danke schon mal ok bin also quasi schon am gehen von ttable ..
ist dann auch das Transaktion Problem geringer ?

TTable möchte eine Transaktion wenn ich eine locate mache und da nur eine Transaktion geht muss ich mini Transaktion machen so das es eigentlich keinen Sinn mehr macht ...

hoika 11. Jan 2011 20:44

AW: ibtable.Locate xy > 10
 
Hallo,
Delphi-Quellcode:
IBQuery.SQL.Text:= 'Select XXX Where Num>10';
IBQuery.Open;
try
  while not IBQuery.Eof do
  begin

    IBQuery.FieldByName().XXX // aktueller Datensatz

    IBQuery.Next;
  end;
finally
  IBQuery.Close;
end;

Heiko

joehd 11. Jan 2011 20:48

AW: ibtable.Locate xy > 10
 
Danke ! :thumb::thumb::thumb::thumb:
Ich benötige noch eine Transaction oder ?
warum benötige ich ein transaction wen ich nur ne liste abfrage ?
ich habe ein bsp aus einem andern Thread gefunden ..
Wie finde ich aber den nächsten gültigen Eintrag :?:


Sorry ihr seht ich fange mit dem mist an aber vielleicht hilft es ja den andern Anfängern in firebird auch
ich arbeite schon ewig mit databases aber nicht mit SQL Servern
sorry :?:

joehd 11. Jan 2011 20:50

AW: ibtable.Locate xy > 10
 
ich wieder das ist ja ein while
dann ist klar der läuft durch bis alle übetragen sind
ist das so richtig
bis eof
DANKE :thumb::shock::idea::cheers:
ich hänge dann mal etwas source an den Thread wenn ich fertig bin damit alle neuen Fische wie ich auch was von haben ...

mano eigentlich ganz einfach

hoika 11. Jan 2011 20:58

AW: ibtable.Locate xy > 10
 
Hallo,

Zitat:

warum benötige ich ein transaction wen ich nur ne liste abfrage ?
Unter IB/FB läuft alles in einer Transaktion
*darf der Frager selber einbauben*

Zitat:

Wie finde ich aber den nächsten gültigen Eintra
Die Query enthält einfach nur alle gültigen Ergebnisse (Num>X).

Es wird vom SQL-Server eine temporäre Tabelle erzeugt,
die nur die gültigen Ergebnisse enthält.
Diese Ergebnis-Tabelle wird mit der Query durchlaufen.

*Sehr Vereinfacht* gesagt.



Heiko

joehd 11. Jan 2011 21:03

AW: ibtable.Locate xy > 10
 
Danke Heiko
und das laufe ich mit einer While durch
oder ist das eine art array ?

ok das probiere ich dann gleich mal
Ist ein ganz anderes denken als bei File Datanbanken


Alle Zeitangaben in WEZ +1. Es ist jetzt 06:09 Uhr.
Seite 1 von 2  1 2      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz