AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Firebird Cursor - Wozu ? Welche Vorteile ?
Thema durchsuchen
Ansicht
Themen-Optionen

Firebird Cursor - Wozu ? Welche Vorteile ?

Ein Thema von lxo · begonnen am 13. Nov 2020 · letzter Beitrag vom 16. Nov 2020
Antwort Antwort
lxo

Registriert seit: 30. Nov 2017
258 Beiträge
 
Delphi 12 Athens
 
#1

Firebird Cursor - Wozu ? Welche Vorteile ?

  Alt 13. Nov 2020, 14:55
Datenbank: Firebird • Version: 3.0.7 • Zugriff über: -
Hallo,

ich bin über die Cursor gestoßen bei Firebird verstehe leider nur nicht ganz wo da der wirkliche Vorteil zu "for select" ist oder wann/wozu sollte man das genau verwenden?
Im Internet bin ich bisher leider nicht ganz schlau daraus geworden.
Könnte mir das vielleicht jemand erklären, wenn es geht mit Beispielen oder sinnvolle Anwendungsfälle dafür nennen?

https://firebirdsql.org/refdocs/lang...forselect.html
https://firebirdsql.org/refdocs/lang...declare-cursor

Geändert von lxo (13. Nov 2020 um 14:57 Uhr)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Firebird Cursor - Wozu ? Welche Vorteile ?

  Alt 13. Nov 2020, 15:09
"Normale" For ...-Schleifen sind von der/den Quell-Tabellen(n) "entkoppelt".
Bei dieser Variante wird das Ergebnis mit einem Cursor verknüpft.
Änderungen an den abgefragten Daten werden direkt ausgeführt und ändert nicht nur die Ergebnismenge sondern auch die Quelldaten.

Vorteile: -schneller, da Änderungen sonst gesondert erfolgen müssen (gesonderte Abfragen; am Besten nach der Schleife).
- U.U. entfällt die Notwendigkeit von tem. Tabellen.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.350 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: Firebird Cursor - Wozu ? Welche Vorteile ?

  Alt 14. Nov 2020, 11:01
Beispiel hier: as cursor clause

Wenn du z.B. in einer Procedure eine Tabelle dürchläufst, um bei bestimmten Datensätzen Änderungen durchzuführen oder zu löschen,
dann kann man sich eine DB-Abfrage sparen und ist deutlich scheller.

Also anstatt:
for select id from mytable into :id
delete from mytable where id = :id

lieber:
for select id from mytable as cursor mycursor
delete from mytable where current of mycursor


Frank
Frank Reim
  Mit Zitat antworten Zitat
lxo

Registriert seit: 30. Nov 2017
258 Beiträge
 
Delphi 12 Athens
 
#4

AW: Firebird Cursor - Wozu ? Welche Vorteile ?

  Alt 16. Nov 2020, 09:02
Beispiel hier: as cursor clause

Wenn du z.B. in einer Procedure eine Tabelle dürchläufst, um bei bestimmten Datensätzen Änderungen durchzuführen oder zu löschen,
dann kann man sich eine DB-Abfrage sparen und ist deutlich scheller.

Also anstatt:
for select id from mytable into :id
delete from mytable where id = :id

lieber:
for select id from mytable as cursor mycursor
delete from mytable where current of mycursor


Frank
Ich glaub jetzt hat es langsam klick gemacht.
Danke euch für die Antworten.
Ich probiere mich da mal etwas aus.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:08 Uhr.
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